亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

C語言實現二叉樹的搜索及相關算法示例

2020-02-24 14:25:31
字體:
來源:轉載
供稿:網友

二叉樹是數據結構和算法的重要組成部分,其實二叉樹的主要目的是解決尋找節點的線性前驅和后繼不方便的問題,下文是武林技術頻道小編和大家分享的C語言實現二叉樹的搜索及相關算法示例,一起去看看吧。

二叉樹(二叉查找樹)是這樣一類的樹,父節點的左邊孩子的key都小于它,右邊孩子的key都大于它。

二叉樹在查找和存儲中通常能保持logn的查找、插入、刪除,以及前驅、后繼,最大值,最小值復雜度,并且不占用額外的空間。

這里演示二叉樹的搜索及相關算法:

#include<stack>#include<queue>using namespace std;class tree_node{public:  int key;  tree_node *left;  tree_node *right;  int tag;  tree_node(){    key = 0;    left = right = NULL;    tag = 0;  }  ~tree_node(){}};void visit(int value){  printf("%d/n", value);}// 插入tree_node * insert_tree(tree_node *root, tree_node* node){  if (!node){    return root;  }  if (!root){    root = node;    return root;  }  tree_node * p = root;  while (p){    if (node->key < p->key){      if (p->left){        p = p->left;      }      else{        p->left = node;        break;      }    }    else{      if (p->right){        p = p->right;      }      else{        p->right = node;        break;      }    }  }  return root;}// 查詢key所在nodetree_node* search_tree(tree_node* root, int key){  tree_node * p = root;  while (p){    if (key < p->key){      p = p->left;    }    else if (key > p->key){      p = p->right;    }    else{      return p;    }  }  return NULL;}// 創建樹tree_node* create_tree(tree_node *t, int n){  tree_node * root = t;  for (int i = 1; i<n; i++){    insert_tree(root, t + i);  }  return root;}// 節點前驅tree_node* tree_pre(tree_node* root){  if (!root->left){ return NULL; }  tree_node* p = root->left;  while (p->right){    p = p->right;  }  return p;}// 節點后繼tree_node* tree_suc(tree_node* root){  if (!root->right){ return NULL; }  tree_node* p = root->right;  while (p->left){    p = p->left;  }  return p;}// 中序遍歷void tree_walk_mid(tree_node *root){  if (!root){ return; }  tree_walk_mid(root->left);  visit(root->key);  tree_walk_mid(root->right);}// 中序遍歷非遞歸void tree_walk_mid_norecursive(tree_node *root){  if (!root){ return; }  tree_node* p = root;  stack<tree_node*> s;  while (!s.empty() || p){    while (p){      s.push(p);      p = p->left;    }    if (!s.empty()){      p = s.top();      s.pop();      visit(p->key);      p = p->right;    }  }}// 前序遍歷void tree_walk_pre(tree_node *root){  if (!root){ return; }  visit(root->key);  tree_walk_pre(root->left);  tree_walk_pre(root->right);}// 前序遍歷非遞歸void tree_walk_pre_norecursive(tree_node *root){  if (!root){ return; }  stack<tree_node*> s;  tree_node* p = root;  s.push(p);  while (!s.empty()){    tree_node *node = s.top();    s.pop();    visit(node->key);    if (node->right){      s.push(node->right);    }    if (node->left){      s.push(node->left);    }  }}// 后序遍歷void tree_walk_post(tree_node *root){  if (!root){ return; }  tree_walk_post(root->left);  tree_walk_post(root->right);  visit(root->key);}// 后序遍歷非遞歸void tree_walk_post_norecursive(tree_node *root){  if (!root){ return; }  stack<tree_node*> s;  s.push(root);  while (!s.empty()){    tree_node * node = s.top();    if (node->tag != 1){      node->tag = 1;      if (node->right){        s.push(node->right);      }      if (node->left){        s.push(node->left);      }    }    else{      visit(node->key);      s.pop();    }  }}// 層級遍歷非遞歸void tree_walk_level_norecursive(tree_node *root){  if (!root){ return; }  queue<tree_node*> q;  tree_node* p = root;  q.push(p);  while (!q.empty()){    tree_node *node = q.front();    q.pop();    visit(node->key);    if (node->left){      q.push(node->left);    }    if (node->right){      q.push(node->right);    }  }}// 拷貝樹tree_node * tree_copy(tree_node *root){  if (!root){ return NULL; }  tree_node* newroot = new tree_node();  newroot->key = root->key;  newroot->left = tree_copy(root->left);  newroot->right = tree_copy(root->right);  return newroot;}// 拷貝樹tree_node * tree_copy_norecursive(tree_node *root){  if (!root){ return NULL; }  tree_node* newroot = new tree_node();  newroot->key = root->key;  stack<tree_node*> s1, s2;  tree_node *p1 = root;  tree_node *p2 = newroot;  s1.push(root);  s2.push(newroot);  while (!s1.empty()){    tree_node* node1 = s1.top();    s1.pop();    tree_node* node2 = s2.top();    s2.pop();    if (node1->right){      s1.push(node1->right);      tree_node* newnode = new tree_node();      newnode->key = node1->right->key;      node2->right = newnode;      s2.push(newnode);    }    if (node1->left){      s1.push(node1->left);      tree_node* newnode = new tree_node();      newnode->key = node1->left->key;      node2->left = newnode;      s2.push(newnode);    }  }  return newroot;}int main(){  tree_node T[6];  for (int i = 0; i < 6; i++){    T[i].key = i*2;  }  T[0].key = 5;  tree_node* root = create_tree(T, 6);  //tree_walk_mid(root);  //tree_walk_mid_norecursive(root);  //tree_walk_pre(root);  //tree_walk_pre_norecursive(root);  //tree_walk_post(root);  //tree_walk_post_norecursive(root);  //tree_walk_level_norecursive(root);  visit(search_tree(root, 6)->key);  visit(tree_pre(root)->key);  visit(tree_suc(root)->key);  //tree_node* newroot = tree_copy_norecursive(root);  //tree_walk_mid(newroot);  return 0;}以上就是關于C語言實現二叉樹的搜索及相關算法示例的全部內容,武林技術頻道小編預祝大家都能學有所成,感謝大家一直以來的支持。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
www.久久久久| 国产成人精彩在线视频九色| 久久久久久69| 午夜欧美大片免费观看| 欧美亚洲在线播放| 欧美不卡视频一区发布| 国产精品日日做人人爱| 国产+成+人+亚洲欧洲| 91在线无精精品一区二区| 在线电影欧美日韩一区二区私密| 亚洲综合成人婷婷小说| 国产亚洲欧美另类中文| 日韩a**站在线观看| 国产成人久久久精品一区| 精品欧美一区二区三区| 欧美极品少妇xxxxⅹ裸体艺术| 成人xxxxx| 成人信息集中地欧美| 日韩福利视频在线观看| 成人激情黄色网| 亚洲精品国产精品乱码不99按摩| 亚洲a区在线视频| 亚洲欧洲在线看| 精品久久久久久亚洲国产300| 欧美电影《睫毛膏》| 国产亚洲视频中文字幕视频| 91国产视频在线播放| 国产精品96久久久久久| 日韩高清电影免费观看完整| 亚洲黄色av网站| 一区二区三区无码高清视频| 精品夜色国产国偷在线| 国产亚洲精品激情久久| 欧美色道久久88综合亚洲精品| 亚洲福利影片在线| 亚洲欧美成人精品| 欧美日韩一区二区精品| 国产精品久久久久一区二区| 精品久久久av| 亚洲va电影大全| 亚洲自拍偷拍区| 91丝袜美腿美女视频网站| 成人在线一区二区| 久久九九精品99国产精品| 欧美激情免费观看| 亚洲视频专区在线| 久久精品视频va| 日韩中文在线视频| 久久久日本电影| www.精品av.com| 亚洲欧美另类在线观看| 亚洲精品av在线| 亚洲国产高清高潮精品美女| 97视频网站入口| 国产一区二区久久精品| 久久久精品2019中文字幕神马| 九九视频直播综合网| 国产在线拍偷自揄拍精品| 亚洲跨种族黑人xxx| 91探花福利精品国产自产在线| 日韩av网址在线观看| 日韩激情av在线免费观看| 日本精品久久久久久久| 亚洲美女动态图120秒| 欧美有码在线观看| 国产精品久久精品| 国产精品吊钟奶在线| 国产精品 欧美在线| 伦伦影院午夜日韩欧美限制| 欧美黄色片视频| 亚洲老板91色精品久久| 国内精品久久久久影院 日本资源| 国产精品99久久99久久久二8| 麻豆国产va免费精品高清在线| 国产在线高清精品| 国产精品视频一| 精品国产户外野外| 日韩第一页在线| 精品毛片网大全| 91理论片午午论夜理片久久| 欧美性jizz18性欧美| 亚洲欧洲视频在线| 成人久久18免费网站图片| 亚洲精品国产精品国自产观看浪潮| 国产精品pans私拍| 欧美精品第一页在线播放| 性亚洲最疯狂xxxx高清| 日韩av在线最新| 国产a级全部精品| 一区二区三区动漫| 狠狠躁天天躁日日躁欧美| 久久91亚洲精品中文字幕奶水| 国产精品扒开腿做| 久久免费少妇高潮久久精品99| 成人午夜在线影院| 亚洲国产福利在线| 欧美日韩国产123| 久久精品中文字幕一区| 超碰日本道色综合久久综合| 91免费人成网站在线观看18| 一区二区三区视频免费在线观看| 久久久精品2019中文字幕神马| 搡老女人一区二区三区视频tv| 日本久久久久久久久久久| 亚洲男人的天堂在线| 欧美精品videos性欧美| 日本精品久久电影| 性欧美xxxx视频在线观看| 欧美日韩激情视频| 国产精品久久久久久久久| 这里只有精品视频| 欧美激情视频在线免费观看 欧美视频免费一| 国产成人精品免高潮在线观看| 亚洲精品美女久久久久| 久久精品男人天堂| 91精品视频播放| 成人有码在线播放| 成人国产精品一区二区| 国产免费亚洲高清| 欧美成人网在线| 国产精品久久久久久中文字| 日韩在线视频网站| 国产精品亚洲视频在线观看| 欧洲午夜精品久久久| 欧美日韩激情网| 亚洲视屏在线播放| 亚洲第一综合天堂另类专| 亚洲男人天堂手机在线| 亚洲一区www| 成人黄色片网站| 日韩av免费网站| 国产欧美在线观看| 午夜免费久久久久| 欧美孕妇毛茸茸xxxx| 色av吧综合网| 精品国产欧美成人夜夜嗨| 国产97在线观看| 久久在线观看视频| 成人亚洲欧美一区二区三区| 性亚洲最疯狂xxxx高清| 伊人久久久久久久久久久久久| 78色国产精品| 国产精品视频公开费视频| 国产精品日韩欧美大师| 91精品综合久久久久久五月天| 97视频在线观看成人| 51久久精品夜色国产麻豆| 91亚洲午夜在线| 日韩av男人的天堂| 疯狂做受xxxx高潮欧美日本| 国产美女精品视频| 黑人巨大精品欧美一区二区一视频| 精品国产欧美一区二区三区成人| 国产成人精品免高潮费视频| 欧美一级电影免费在线观看| 国产精品网址在线| 亚洲永久在线观看| 成人网中文字幕| 国产91av在线| 欧美视频在线观看免费| 国产午夜精品理论片a级探花| 狠狠躁夜夜躁人人躁婷婷91| 欧美孕妇孕交黑巨大网站| 国产专区精品视频|