欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c++實現(xiàn)二叉查找樹示例

 更新時間:2014年02月28日 11:35:14   作者:  
這篇文章主要介紹了c++實現(xiàn)二叉查找樹示例,實現(xiàn)二叉查找樹的基本功能,需要的朋友可以參考下

復(fù)制代碼 代碼如下:

/**
 實現(xiàn)二叉查找樹的基本功能
*/

#include <iostream>
#include <cstring>
#include <algorithm>
#include <cstdio>
#include <string>

using namespace std;

const int M = 10000;

//定義數(shù)據(jù)節(jié)點
class dNode{
public:
 string name;
 int age;
 bool sex;
 dNode(){
  age = 0;
  name = "no name";
  sex = true;//nan
 }
 dNode(string name, int age, bool sex):name(name), age(age), sex(sex){}
 //打印節(jié)點
 void show(){
  cout << "name: " << this->name << endl;
  cout << "age: " << this->age << endl;
  cout << "sex: " << this->sex << endl;
  cout << "******************************" << endl;
 }
 //重載賦值符號
 bool operator = (const dNode &d){
  this->age = d.age;
  this->name = d.name;
  this->sex = d.sex;
 }
 //重載相等符號
 bool operator == (const dNode &d){
  return name == d.name && age == d.age && sex == sex;
 }
 //按照年齡重載大于符號
 bool operator > (const dNode &d){
  return age > d.age;
 }
 //按照年齡重載小于符號
 bool operator < (const dNode &d){
  return age < d.age;
 }

};
//定義二叉查找樹的節(jié)點
//這里規(guī)定樹中沒有重復(fù)節(jié)點,這里需要對一個節(jié)點記錄出現(xiàn)多少次
class bstNode{
public: 
 bstNode *left;
 bstNode *right;
 bstNode *parent; //執(zhí)行父親,便于向上訪問,如果數(shù)據(jù)量大,并且向上找的使用率不大就不要來減少空間
 dNode data;  //該節(jié)點在樹中出現(xiàn)的次數(shù)
 int count;
 bstNode(){
  left = right = parent = NULL;
  count = 1;
 }
};
//定義二叉樹
class bst{
private:
 //清理整棵樹
 //注意,一定一定要后續(xù)遍歷的方法清理
 void destory(bstNode *cur){
  if(NULL == cur){
   return;
  }
  cout << "clearing" << endl;
  destory(cur->left);
  destory(cur->right);
  delete cur; //后續(xù)清理
 }
 //真正的刪除節(jié)點
 void _del(bstNode * cur, bstNode *delNode);
public:
 bstNode * root = NULL;
 bst(){
  root = NULL;
 }
 //插入,返回值是便于構(gòu)造parent關(guān)系
 bstNode * insert(bstNode *& cur, dNode data);
 //搜索
 bstNode * search(bstNode * cur, dNode data);
 //先序遍歷
 void pre_raversal(bstNode *cur);
 //返回cur為根的節(jié)點的最小值
 bstNode * minNode(bstNode *cur);
 //得到cur節(jié)點的后繼
 bstNode * succNode(bstNode *cur);
 //刪除節(jié)點,如果count大于1就將count - 1,如果count==1就清除該節(jié)點,返回清除的節(jié)點的地址
 bstNode * del(bstNode *cur, dNode data);
 //構(gòu)造函數(shù)對樹做清理工作
 virtual ~bst(){
  cout << "###start clear###" << endl;
  this->destory(root);
  cout << "###clear ok###" << endl;
 }

};
bstNode * bst::insert(bstNode *& cur, dNode data){
 if(NULL == cur){
  bstNode * newNode = new bstNode();
  newNode->data = data;
  cur = newNode;
  return cur;
 }else if(cur->data == data){
  cur->count++;
 }else if(cur->data > data){
  bst::insert(cur->left, data)->parent = cur;
 }else if(cur->data < data){
  bst::insert(cur->right, data)->parent = cur;
 }
}
bstNode * bst::search(bstNode *cur, dNode data){
 if(NULL == cur){
  return NULL;
 }else if(cur->data == data){
  return cur;
 }else if(cur->data > data){
  return cur->left;
 }else if(cur->data < data){
  return cur->right;
 }
}
void bst::pre_raversal(bstNode *cur){
 if(NULL == cur)
  return;
 bst::pre_raversal(cur->left);
 cout << "count: " << cur->count << endl;
 cur->data.show();
 bst::pre_raversal(cur->right);
}
bstNode * bst::minNode(bstNode *cur){
 if(NULL == cur){
  return NULL; //如果根節(jié)點是空,就返回空
 }else{
  if(NULL != cur->left){
   return minNode(cur->left);
  }
 }
}
/**
* 非遞歸
* 后繼就是比cur節(jié)點剛好大一點兒的節(jié)點A(排序之后),那么思
* 路就是找cur節(jié)點的右子樹中的最小值或者是在cur的祖先中找到第一個比剛好大一點兒的那個節(jié)點
* ***找到A有兩種情況:
* 1.cur節(jié)點有右子樹,那么就找右子樹的最小值節(jié)點就好了
* 2.cur節(jié)點沒有右子樹,那么一級一級的向祖先找,直到某個祖先節(jié)點A滿足,
*   A的左孩子是cur的祖先,因為當(dāng)A的左孩子是cur祖先就說明查找路線在想右
*   偏了,之前一直是往左邊偏
*/
bstNode * bst::succNode(bstNode *cur){
 if(NULL != cur->right){
  return minNode(cur);
 }
 bstNode * parentNode = cur->parent;
 while(NULL != parentNode && parentNode->right == cur){
  cur = parentNode;
  parentNode = parentNode->parent;
 }
 return parentNode;
}

/**
*
* 刪除c節(jié)點,這個是最難的
* 規(guī)定:要刪除的節(jié)點是c, c的父節(jié)點是p, c的后繼是s,c的左孩子是l,有孩子是r
* 刪除c整個節(jié)點(不是count-1)分三種情況
* 1. c節(jié)點沒有孩子,直接刪除
* 2. c節(jié)點有一個孩子,那么直接將孩子節(jié)點(l或r)指向c的父節(jié)點p(p也要執(zhí)行l(wèi)或r)
* 3. c有兩個孩子,那么需要用后繼節(jié)s點里面的數(shù)據(jù)掉替換c節(jié)點里面的數(shù)據(jù),然后再刪除s節(jié)點
*    同時需要將s父子之間的指向關(guān)系處理好
*/
void bst::_del(bstNode * cur, bstNode *delNode){
 if(NULL == delNode->left || NULL == delNode->right){
  //待續(xù)
 }
}

/**
*接口:
*跟count有關(guān)的刪除
*/
bstNode * bst::del(bstNode *cur, dNode data){
 //先找到需要刪除的節(jié)點
 bstNode * delNode = this->search(cur, data);
 if(NULL == delNode) //沒有找到該節(jié)點,無需刪除
  return NULL;
 if(delNode->count == 1){
  _del(this->root, delNode);
 }else{
  delNode->count--;
 }
}

int main(){
 bst *root = new bst();
 //構(gòu)造50個人, 重復(fù)的雖然在樹中不會重復(fù)插入,但是會被計數(shù)
 int num = 50;
 for(int i = 0; i < num; i++){
  dNode * newData = new dNode("Luo", rand() % 15, rand() % 2);
  root->insert(root->root, *newData);
 }
 //前序遍歷
 root->pre_raversal(root->root);

 bstNode *searchNode = root->search(root->root, *new dNode("Luo", 3, 1));
 cout << "#######search a Node ##########" << endl;
 if(NULL == searchNode){
  cout << "沒有找到該節(jié)點" << endl;
 }else{
  cout << "count: " << searchNode->count << endl;
  searchNode->data.show();
 }
 //清理整棵樹
 delete root;

 return 0;
}

相關(guān)文章

  • C++11中條件標(biāo)量和互斥鎖應(yīng)用出現(xiàn)死鎖問題

    C++11中條件標(biāo)量和互斥鎖應(yīng)用出現(xiàn)死鎖問題

    這篇文章主要介紹了C++11中條件標(biāo)量和互斥鎖應(yīng)用出現(xiàn)死鎖思考,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • 二叉樹入門和刷題詳解

    二叉樹入門和刷題詳解

    這篇文章主要介紹了二叉樹入門和刷題詳解的相關(guān)資料,需要的朋友可以參考下
    2023-07-07
  • C++中異常機(jī)制的實現(xiàn)機(jī)制詳解

    C++中異常機(jī)制的實現(xiàn)機(jī)制詳解

    這篇文章主要給大家介紹了關(guān)于C++中異常機(jī)制的實現(xiàn)機(jī)制的相關(guān)資料,文中通過圖文以及示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-06-06
  • C語言中的指針新手初階指南

    C語言中的指針新手初階指南

    指針是C語言的靈魂,精華之所在,指針強(qiáng)大而危險,用得好是一大利器,用得不好是一大潛在危害,下面這篇文章主要給大家介紹了C語言中指針的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-10-10
  • C語言制作表白神器的示例代碼

    C語言制作表白神器的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何利用C語言制作一個簡單的表白神器,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,感興趣的小伙伴可以了解一下
    2023-03-03
  • C語言關(guān)于自定義數(shù)據(jù)類型之枚舉和聯(lián)合體詳解

    C語言關(guān)于自定義數(shù)據(jù)類型之枚舉和聯(lián)合體詳解

    枚舉顧名思義就是把所有的可能性列舉出來,像一個星期分為七天我們就可以使用枚舉,聯(lián)合體是由關(guān)鍵字union和標(biāo)簽定義的,和枚舉是一樣的定義方式,不一樣的是,一個聯(lián)合體只有一塊內(nèi)存空間,什么意思呢,就相當(dāng)于只開辟最大的變量的內(nèi)存,其他的變量都在那個變量占據(jù)空間
    2021-11-11
  • C++初級線程管理

    C++初級線程管理

    這篇文章主要介紹了C++初級線程管理,C++11中提供了std::thread庫,本文將從線程的啟動、線程等待、線程分離、線程傳參、線程識別等幾個方面介紹初級線程管理的知識,需要的朋友可以參考一下
    2021-12-12
  • 基于C語言實現(xiàn)shell指令的詳解

    基于C語言實現(xiàn)shell指令的詳解

    本篇文章是對C語言實現(xiàn)shell指令的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C++中線程池ThreadPool源碼解析

    C++中線程池ThreadPool源碼解析

    線程池(threadpool)作為五大池之一(內(nèi)存池、連接池、線程池、進(jìn)程池、協(xié)程池),線程池的應(yīng)用非常廣泛,不管事客戶端程序還是后臺服務(wù)端,都是提高業(yè)務(wù)處理能力的必備模塊
    2022-09-09
  • C/C++根據(jù)年月日計算星期幾(蔡勒公式篇)

    C/C++根據(jù)年月日計算星期幾(蔡勒公式篇)

    這篇文章主要給大家介紹了關(guān)于C/C++根據(jù)年月日計算星期幾(蔡勒公式篇)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03

最新評論