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

隨筆-80  評(píng)論-24  文章-0  trackbacks-0
假設(shè)已經(jīng)有了前序遍歷和中序遍歷的結(jié)果,希望通過(guò)一個(gè)算法重建這棵樹。已知遍歷結(jié)果為字符串,且樹的每個(gè)節(jié)點(diǎn)的value都是一個(gè)字符,且各不相同。
如,前序:a b d c e f
中序:d b a e c f
則由前序可知,樹的根必定是前序遍歷的第一個(gè)節(jié)點(diǎn)a,再找a在中序中的位置,則可知道中序遍歷中a之前的所有節(jié)點(diǎn)都是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 }

如果已經(jīng)知道了中序遍歷結(jié)果和后序遍歷結(jié)果,那么如何重構(gòu)二叉樹呢?其實(shí)仔細(xì)想想,它和知道前序和中序來(lái)構(gòu)造二叉樹的原理是一樣,只不過(guò)后序的根節(jié)點(diǎn)在序列的最后,只要知道根節(jié)點(diǎn)那么就可以去掃描中序序列,然后確定左子樹和右子樹,代碼如下:

 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 }

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

 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   }

由前序和中序重構(gòu)二叉樹的非遞歸算法和上面相似,就是對(duì)前序由前向后掃描,具體算法就不寫出來(lái)了
posted on 2012-09-03 14:24 myjfm 閱讀(574) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 算法基礎(chǔ)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美视频在线观看视频| 亚洲视频电影图片偷拍一区| 欧美视频在线免费| 欧美aa在线视频| 国产酒店精品激情| 夜夜嗨av一区二区三区网站四季av| 韩国av一区二区| 亚洲一区二区久久| 一本一本大道香蕉久在线精品| 久久久999精品视频| 欧美一区二区三区另类| 国产精品99免费看| 亚洲精品在线三区| 亚洲人成艺术| 米奇777超碰欧美日韩亚洲| 久久大逼视频| 国产亚洲精品久久飘花| 午夜在线播放视频欧美| 亚洲欧洲av一区二区| 欧美亚州一区二区三区 | 欧美极品一区| 亚洲成人直播| 亚洲精品免费看| 欧美成年人视频| 最新成人av网站| aa级大片欧美| 国产精品电影在线观看| 在线亚洲美日韩| 亚洲欧美日韩国产综合在线| 国产精品久久9| 亚洲欧美成人一区二区三区| 亚洲精品网站在线播放gif| 久久婷婷综合激情| 亚洲大片在线| 亚洲精品美女在线观看| 女主播福利一区| 欧美激情一区二区在线| 亚洲精品欧美在线| 欧美国产国产综合| 亚洲人成网站777色婷婷| 亚洲精品一区二区三区福利| 欧美国产高清| 亚洲精品美女在线| 这里只有精品丝袜| 欧美视频在线一区二区三区| 一本色道久久综合亚洲精品婷婷 | 99ri日韩精品视频| 欧美日韩成人激情| 亚洲一级二级| 久久精品99无色码中文字幕| 国产精品久久久久久模特| 在线视频精品| 亚洲免费观看高清完整版在线观看| 欧美激情综合五月色丁香| 日韩特黄影片| 欧美专区一区二区三区| 一色屋精品亚洲香蕉网站| 免费国产一区二区| 亚洲精品社区| 欧美在线视频一区| 精品电影在线观看| 欧美黄色一区二区| 亚洲永久免费观看| 久久亚洲一区二区| 999亚洲国产精| 国产精品网红福利| 久久丁香综合五月国产三级网站| 亚洲三级影院| 欧美在线观看一区| 亚洲国产成人久久综合一区| 欧美日韩亚洲免费| 欧美一激情一区二区三区| 欧美高清视频一区二区三区在线观看| 亚洲免费av网站| 国产三级精品在线不卡| 免费人成精品欧美精品| 亚洲在线观看免费视频| 免费久久久一本精品久久区| 亚洲视频中文字幕| 狠狠综合久久| 国产精品v片在线观看不卡| 久久久精品国产免大香伊| 日韩视频一区| 老司机久久99久久精品播放免费 | 欧美日韩国产一区二区三区| 亚洲性感美女99在线| 欧美福利视频在线| 久久精品国产亚洲一区二区三区| 亚洲六月丁香色婷婷综合久久| 国产精品伊人日日| 欧美精品一区二区在线观看| 欧美专区日韩专区| av成人免费在线观看| 亚洲国产成人午夜在线一区| 欧美在线短视频| 中文在线资源观看视频网站免费不卡| 国产在线乱码一区二区三区| 欧美午夜www高清视频| 欧美jjzz| 老司机精品视频一区二区三区| 亚洲一区中文字幕在线观看| 日韩视频精品在线观看| 亚洲国产女人aaa毛片在线| 久久久人成影片一区二区三区观看 | 欧美激情在线狂野欧美精品| 久久不射网站| 午夜天堂精品久久久久| 一本久道久久综合中文字幕| 亚洲精品乱码久久久久久按摩观| 免费永久网站黄欧美| 久久久亚洲国产天美传媒修理工 | 欧美搞黄网站| 欧美91视频| 久久综合给合久久狠狠狠97色69| 欧美一级在线亚洲天堂| 亚洲一区二区三区在线播放| 99精品国产在热久久下载| 狠狠久久五月精品中文字幕| 国产精品乱人伦一区二区| 欧美日本不卡高清| 欧美h视频在线| 欧美黄色影院| 欧美日韩国产小视频在线观看| 欧美精品久久久久久久| 欧美电影免费观看高清| 欧美国产日韩xxxxx| 欧美激情在线免费观看| 欧美黄免费看| 欧美色精品天天在线观看视频| 欧美三级电影网| 国产精品久久久久久久久久久久久 | 久久精品男女| 久久久久一区| 欧美高清视频www夜色资源网| 欧美成人免费视频| 亚洲激情视频| 99综合视频| 香蕉久久夜色精品| 欧美中文在线观看| 亚洲欧美日本日韩| 久久久国产精品一区二区中文 | 亚洲精品乱码久久久久久久久| 亚洲精品久久久久久一区二区| 一本久道久久综合狠狠爱| 亚洲在线免费视频| 欧美一区二区视频在线观看2020| 久久午夜av| 欧美日韩一区精品| 国产一区二区三区四区五区美女| 有码中文亚洲精品| 在线亚洲高清视频| 久久国产精品一区二区| 免费在线欧美视频| 一区二区三区国产在线| 久久成人国产| 欧美日本一道本在线视频| 国产视频精品免费播放| 亚洲激情视频在线| 亚洲视频每日更新| 巨乳诱惑日韩免费av| 日韩一区二区福利| 久久精品毛片| 欧美午夜片在线观看| 激情一区二区| 亚洲综合99| 欧美国产一区在线| 午夜精品剧场| 欧美激情亚洲自拍| 国产亚洲一级高清| 中文有码久久| 欧美国产日韩一区二区在线观看| 一区二区三区|亚洲午夜| 欧美亚洲免费电影| 欧美电影美腿模特1979在线看| 黄色在线成人| 亚洲欧美中文日韩在线| 亚洲精华国产欧美| 久久久久久日产精品| 国产精品毛片一区二区三区| 亚洲精品日韩欧美| 老鸭窝91久久精品色噜噜导演| 在线亚洲伦理| 欧美精品一区二区三区很污很色的| 国产一区自拍视频| 亚洲一区二区黄| 亚洲免费观看高清在线观看| 久久婷婷人人澡人人喊人人爽| 国产精品日韩精品欧美精品| 一本一本a久久| 亚洲电影一级黄| 久久婷婷国产综合精品青草| 国产日韩综合| 亚洲免费中文字幕| 日韩午夜中文字幕| 欧美日韩高清在线播放| 亚洲人成艺术| 久久av一区二区| 99精品久久免费看蜜臀剧情介绍| 欧美国产专区| 亚洲精品视频在线看|