青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-80  評論-24  文章-0  trackbacks-0
假設已經有了前序遍歷和中序遍歷的結果,希望通過一個算法重建這棵樹。已知遍歷結果為字符串,且樹的每個節點的value都是一個字符,且各不相同。
如,前序:a b d c e f
中序:d b a e c f
則由前序可知,樹的根必定是前序遍歷的第一個節點a,再找a在中序中的位置,則可知道中序遍歷中a之前的所有節點都是a的左子樹,這樣,就可以遞歸建立左子樹,同樣中序遍歷中a右邊的序列是a的右子樹,遞歸建立即可。
代碼如下:

 1 struct NODE {
 2   NODE* left;
 3   NODE* right;
 4   char value;
 5 };
 6 
 7 void rebuild_bitree(char *pre_order, 
 8     char *in_order, 
 9     int treelen, 
10     NODE **root) {
11   assert(root != NULL);
12   if (pre_order == NULL ||  
13       in_order == NULL ||  
14       treelen <= 0) {
15     return;
16   }
17   if (*root == NULL) {
18     *root = new NODE;
19   }
20   (*root)->value = pre_order[0];
21   (*root)->left = (*root)->right = NULL;
22   int i = 0;
23   for (i = 0; i < treelen; ++i) {
24     if (in_order[i] == pre_order[0]) {
25       break;
26     }   
27   }
28   rebuild_bitree(pre_order + 1,  
29       in_order, 
30       i,  
31       &((*root)->left));
32   rebuild_bitree(pre_order + i + 1,  
33       in_order + i + 1,  
34       treelen - i - 1,  
35       &((*root)->right));
36 }

如果已經知道了中序遍歷結果和后序遍歷結果,那么如何重構二叉樹呢?其實仔細想想,它和知道前序和中序來構造二叉樹的原理是一樣,只不過后序的根節點在序列的最后,只要知道根節點那么就可以去掃描中序序列,然后確定左子樹和右子樹,代碼如下:

 1 void rebuild_bitree(char *in_order, 
 2     char *post_order, 
 3     int treelen, 
 4     NODE **root) {
 5   if (in_order == NULL || 
 6       post_order == NULL || 
 7       treelen <= 0) {
 8     return;
 9   }
10 
11   if (*root == NULL) {
12     *root = new NODE;
13   }
14   (*root)->value = post_order[treelen - 1];
15   (*root)->left = (*root)->right = NULL;
16 
17   int i = 0;
18   for (i = 0; i < treelen; ++i) {
19     if (in_order[i] == post_order[treelen - 1]) {
20       break;
21     }
22   }
23 
24   rebuild_bitree(in_order, 
25       post_order, 
26       i, 
27       &(*root)->left);
28   rebuild_bitree(in_order + i + 1, 
29       post_order + i, 
30       treelen - i - 1, 
31       &(*root)->right);
32 }

上面寫出的都是遞歸算法,因為遞歸本質上就是利用棧來操作,所以,如果要采用非遞歸算法來實現的話該如何做呢?現在還是以知道后序和中序,來重建二叉樹,還是前面的例子:
中序:d b a e c f 
后序:d b e f c a
1、還是先用一個棧保存后序中的節點在中序中的索引值,初始棧為空
2、對后序從后向前掃描,1)若棧為空,則該節點直接入棧;2)若當前節點在中序中的索引值大于棧頂節點在中序中的索引值,則可知該節點為棧頂節點的右孩子;3)只要當前節點在中序中的索引值小于棧頂 節點在中序節點中的索引值,就連續出棧,當前節點是最后一個出棧節點的左孩子;
這樣程序如下:

 1 void rebuild_bitree(char *in_order,                                                                               
 2     char *post_order, 
 3     int treelen, 
 4     NODE **root) {
 5   if (in_order == NULL || post_order == NULL || treelen <= 0) {
 6     return;
 7   }
 8   if (*root == NULL) {
 9     *root = new NODE;
10     (*root)->value = post_order[treelen - 1];
11     (*root)->left = (*root)->right = NULL;
12   }
13   std::stack<int> index_stack;
14   std::stack<NODE *> node_stack;
15   int i;
16   int j;
17   NODE *tmp1;
18   NODE *tmp2;
19   for (i = treelen - 1; i >= 0; --i) {
20     if (i == treelen - 1) {
21       tmp1 = *root;
22     } else {
23       tmp1 = new NODE;
24       tmp1->value = post_order[i];
25       tmp1->left = tmp1->right = NULL;
26     }
27     for (j = 0; j < treelen; ++j) {
28       if (in_order[j] == post_order[i]) {
29         break;
30       }
31     }
32     if (index_stack.empty()) {
33       index_stack.push(j);
34       node_stack.push(tmp1);
35     } else if (j > index_stack.top()) {
36       node_stack.top()->right = tmp1;
37       index_stack.push(j);
38       node_stack.push(tmp1);
39     } else {
40       while (!index_stack.empty() && j < index_stack.top()) {
41         index_stack.pop();
42         tmp2 = node_stack.top();
43         node_stack.pop();
44       }
45       tmp2->left = tmp1;
46       index_stack.push(j);
47       node_stack.push(tmp1);
48     }
49   }

由前序和中序重構二叉樹的非遞歸算法和上面相似,就是對前序由前向后掃描,具體算法就不寫出來了
posted on 2012-09-03 14:24 myjfm 閱讀(574) 評論(0)  編輯 收藏 引用 所屬分類: 算法基礎
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品99久久99久久久二8| 欧美黄色免费| 日韩一区二区精品在线观看| 欧美一区二区三区在线视频| 亚洲天堂成人在线观看| 美女在线一区二区| 久久综合国产精品台湾中文娱乐网| 欧美日韩国产成人在线91| 免费亚洲网站| 国产麻豆午夜三级精品| 亚洲精品久久久久久久久久久| 国产综合香蕉五月婷在线| 一本色道久久精品| 日韩一区二区精品视频| 老妇喷水一区二区三区| 久久综合一区二区| 国产日产欧产精品推荐色| 亚洲香蕉在线观看| 亚洲影音先锋| 国产精品乱人伦中文| 99视频日韩| 亚洲摸下面视频| 国产精品扒开腿做爽爽爽视频 | 国产精品专区一| 中日韩男男gay无套| 夜夜精品视频一区二区| 欧美人成在线视频| 日韩午夜av电影| 亚洲尤物视频在线| 国产精品高精视频免费| 亚洲一级影院| 欧美一区在线看| 国产亚洲一区二区三区在线观看 | 亚洲日本中文字幕| 日韩亚洲一区二区| 欧美精品一区二区三区很污很色的 | 久久国产精品一区二区| 国产欧美日本一区视频| 性久久久久久久| 久久久亚洲影院你懂的| 激情婷婷欧美| 你懂的国产精品| 91久久精品www人人做人人爽| 99re6热在线精品视频播放速度 | 国产精品第13页| 亚洲一区二区三区免费在线观看| 午夜在线成人av| 激情婷婷久久| 欧美人牲a欧美精品| 日韩小视频在线观看专区| 午夜欧美大尺度福利影院在线看| 国产精品亚洲一区| 久久久久九九九九| 亚洲国产综合在线| 亚洲午夜在线视频| 国产在线精品一区二区夜色| 久久久之久亚州精品露出| 亚洲精品小视频| 小黄鸭精品密入口导航| 亚洲福利视频三区| 欧美午夜在线观看| 久久成人在线| 亚洲美女网站| 久久久久久免费| 99精品视频免费观看视频| 国产精品一区二区在线观看不卡 | 在线不卡免费欧美| 欧美成在线视频| 亚洲欧美在线另类| 欧美激情一区二区三级高清视频 | 欧美一区二区三区免费视频| 欧美韩日精品| 久久av一区| 一区二区三区不卡视频在线观看| 国产一区91| 欧美日韩你懂的| 久久综合狠狠| 午夜激情亚洲| 夜夜嗨一区二区三区| 美国十次了思思久久精品导航| 亚洲视频一区在线| 最新日韩av| 国产午夜精品全部视频播放| 欧美喷水视频| 麻豆av一区二区三区久久| 亚洲免费一在线| 亚洲精品欧美日韩| 亚洲成色最大综合在线| 久久国内精品自在自线400部| 在线亚洲观看| 亚洲精品国产视频| 在线观看欧美视频| 国产手机视频一区二区| 国产精品劲爆视频| 欧美成人在线免费视频| 久久夜色精品国产| 西西人体一区二区| 亚洲综合丁香| 亚洲一区二区精品在线观看| 夜夜爽www精品| 亚洲看片一区| 亚洲三级免费观看| 亚洲日本免费电影| 亚洲高清不卡在线| 欧美成人在线免费观看| 美日韩精品免费| 久久综合久久88| 狼人天天伊人久久| 久久这里只有精品视频首页| 久久精精品视频| 久久久久久久一区二区三区| 久久久久国产一区二区三区| 久久精品一区二区三区四区| 久久精品视频导航| 久久精品国产77777蜜臀| 久久精品国产99| 久久久久**毛片大全| 久久综合亚州| 欧美二区视频| 亚洲欧洲日本mm| 99视频精品免费观看| 一本一本久久a久久精品综合妖精| 亚洲三级网站| 亚洲伊人色欲综合网| 午夜精品一区二区三区电影天堂| 欧美制服丝袜| 久久一区欧美| 欧美日韩国产成人| 国产精品国产成人国产三级| 国产精品专区h在线观看| 今天的高清视频免费播放成人| 在线播放日韩专区| 亚洲另类视频| 午夜日韩av| 欧美h视频在线| 亚洲美女视频网| 午夜视黄欧洲亚洲| 蜜桃久久精品一区二区| 欧美日韩一区二区三区在线| 国产精品一区二区你懂得| 狠狠狠色丁香婷婷综合久久五月| 亚洲国产天堂久久国产91| 亚洲色图在线视频| 久久久久久一区二区| 亚洲二区在线| 亚洲综合导航| 蜜桃av噜噜一区| 国产伦精品一区二区三区| 亚洲国产精选| 午夜精品亚洲一区二区三区嫩草| 农夫在线精品视频免费观看| 一本色道久久综合亚洲精品不卡| 欧美一区免费视频| 欧美日韩a区| 国内精品国产成人| 亚洲新中文字幕| 欧美成黄导航| 亚洲欧美日韩中文视频| 欧美丰满高潮xxxx喷水动漫| 国产欧美日韩在线| 夜夜嗨网站十八久久| 久久久噜噜噜久久狠狠50岁| 亚洲精品免费电影| 欧美在线电影| 国产精品扒开腿做爽爽爽视频 | 影音先锋欧美精品| 亚洲欧美三级在线| 欧美激情一区二区三区不卡| 亚洲欧美网站| 欧美色123| 亚洲人在线视频| 免费成人你懂的| 午夜精品久久久久久久男人的天堂 | 性色av一区二区三区| 亚洲日韩视频| 免费久久99精品国产自| 国外视频精品毛片| 欧美亚洲在线视频| 一本久久a久久精品亚洲| 欧美黑人国产人伦爽爽爽| 在线观看免费视频综合| 久久av一区二区三区| 一区二区电影免费在线观看| 欧美高清视频一区| 亚洲成色www8888| 麻豆成人综合网| 久久gogo国模裸体人体| 国产精品日韩精品欧美精品| 亚洲一区二区精品在线| 日韩一区二区电影网| 欧美理论电影在线播放| 亚洲乱码精品一二三四区日韩在线 | 亚洲专区在线视频| 99热这里只有精品8| 欧美无乱码久久久免费午夜一区| 在线视频欧美日韩精品| 日韩午夜在线观看视频| 欧美日韩精品二区第二页| 一区二区三区四区国产| 亚洲美女视频在线观看|