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

二叉樹前序,中序,后序遍歷的非遞歸實現(c++版)

1. 二叉樹后序非遞歸遍歷:

 1#include <stack>
 2#include <iostream>
 3using namespace std;
 4
 5template <class T>
 6class TreeNode
 7{
 8  public:
 9    T data;
10    TreeNode<T> *left; //left child
11    TreeNode<T> *right; //right child
12 
13    TreeNode():left(NULL),right(NULL)
14    {
15    }

16
17    TreeNode(const T& t):data(t),left(NULL), right(NULL)
18    {
19    }

20
21    TreeNode(const T& t, TreeNode<T*> left, TreeNode<T*> right):data(t),left(left), right(right)
22    {
23    }

24}
;
25
26/**purpose: 對二叉樹進行后序遍歷(非遞歸算法)
27 TreeNode<T> *root :the root of the binary tree
28  */

29template <class T>
30void postOrder(TreeNode<T> *root)
31{
32  stack<TreeNode<T>*> st;
33  TreeNode<T> *= root;
34  TreeNode<T> *pre = NULL;//pre表示最近一次訪問的結點
35 
36  while(p || st.size()!=0)
37  {
38    //沿著左孩子方向走到最左下 。
39    while(p)
40    {
41      st.push(p);
42      p = p->left;
43    }

44    //get the top element of the stack
45    p = st.top();
46    //如果p沒有右孩子或者其右孩子剛剛被訪問過,則訪問p節點,并從棧中刪除
47   if(p->right == NULL || p->right == pre)
48    {
49      //visit this element and then pop it
50      cout << "visit: " << p->data << endl;
51      st.pop();
52      pre = p; //標記最近被訪問的節點
53      p = NULL; //這樣,接下來可以訪問父節點
54     
55    }

56   else
57   {
58     p = p->right;
59    
60   }

61  }
//end of while(p || st.size()!=0)
62
63}

64
65


2.二叉樹前序非遞歸遍歷:

 1template <class T>
 2void PreOrder(TreeNode<T> *root)const
 3{
 4    stack<TreeNode<T>*> st;
 5    TreeNode<T>* p=root;
 6
 7    while (!st.empty()||p!=NULL)
 8    {
 9        while(p)   //沿左子樹到底,訪問途中結點并壓棧保存
10        {
11            cout<<"visit:"<<p->data<<endl;
12            st.push(p);
13            p=p->left;
14        }

15
16        p=st.top(); //將父結點出棧,對右子樹訪問
17        st.pop();
18        p=p->right;        
19
20    }

21
22
23}

3.二叉樹中序非遞歸遍歷:
 

 1void InOrder(TreeNode<T>*root)const
 2{
 3    stack<TreeNode<T>*> st;
 4    TreeNode<T>* p=root;
 5    while (!st.empty()||p!=NULL)
 6    {
 7        while(p)//沿左子樹到底,將途中結點壓棧保存,不訪問
 8        {
 9            st.push(p);
10            p=p->left;
11        }

12        p=st.top();
13        cout<<"visit:"<<p->data<<endl; //此時訪問,實現中序
14        st.pop();
15        p=p->right;
16
17    }

18
19}

posted on 2010-10-22 19:05 oliver 閱讀(1625) 評論(1)  編輯 收藏 引用 所屬分類: DataStructure

評論

# re: 二叉樹前序,中序,后序遍歷的非遞歸實現(c++版) 2012-11-22 23:11 missgya

看了這么多,發現閣下的后序遍歷寫得最漂亮。  回復  更多評論   

<2012年11月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

導航

統計

常用鏈接

留言簿

隨筆檔案

文章分類

文章檔案

個人專欄

技術網站

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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热| 久久久久久伊人| 99精品欧美一区二区三区综合在线 | 欧美在线视频观看免费网站| 欧美国产欧美亚洲国产日韩mv天天看完整| 在线午夜精品| 亚洲视频视频在线| 亚洲在线视频| 午夜精品久久久久影视 | 国产精品爱久久久久久久| 欧美视频一区二区三区…| 国产精品视频免费观看| 国产欧美一区二区三区在线看蜜臀 | 亚洲欧美日韩综合| 久久精品成人一区二区三区蜜臀| 久久久亚洲人| 国产精品红桃| 亚洲人成网站精品片在线观看| 日韩一级片网址| 久久精品水蜜桃av综合天堂| 亚洲一区一卡| 久久手机精品视频| 亚洲人在线视频| 在线视频欧美日韩精品| 午夜在线观看欧美| 欧美啪啪成人vr| 在线播放一区| 久久国产精品网站| 亚洲激情欧美| 久久一区二区三区av| 国产精品一区久久久| 亚洲色图制服丝袜| 亚洲精品小视频| 欧美大片在线看免费观看| 国产日韩在线一区| 久久精品国产亚洲5555| 亚洲欧美电影院| 国产亚洲欧美一区在线观看| 午夜精品福利一区二区蜜股av| 亚洲精品日韩在线观看| 欧美视频一区在线| 性色av一区二区三区在线观看 | 亚洲网站在线观看| 中文成人激情娱乐网| 欧美日韩一区综合| 小嫩嫩精品导航| 一区二区三区在线看| 欧美福利电影在线观看| 欧美一区网站| 久久国产欧美| 一本色道精品久久一区二区三区 | 亚洲人成人99网站| 欧美日韩中文| 久久精品视频导航| 欧美精品一级| 欧美超级免费视 在线| 欧美日韩第一区| 久久婷婷国产麻豆91天堂| 欧美日韩国产亚洲一区| 麻豆freexxxx性91精品| 欧美日韩国内| 亚洲第一福利在线观看| 国产精品成人久久久久| 麻豆国产精品va在线观看不卡| 欧美精品免费视频| 欧美大片在线影院| 国产综合香蕉五月婷在线| 日韩午夜剧场| 亚洲视频免费| 欧美日韩视频一区二区| 亚洲高清自拍| 91久久国产综合久久蜜月精品 | 久久久久久久久久久一区 | 韩国精品在线观看| 亚洲在线成人| 性亚洲最疯狂xxxx高清| 欧美另类一区二区三区| 欧美激情乱人伦| 夜夜夜精品看看| 国产精品乱码人人做人人爱| 亚洲精品社区| 久久爱另类一区二区小说| 国产视频一区在线观看| 久久久噜噜噜久久狠狠50岁| 国产精品丝袜91| 久久久久久97三级| 亚洲欧洲精品天堂一级| 国产精品99久久久久久久女警| 国产精品日产欧美久久久久| 午夜在线精品偷拍| 老司机精品久久| 一区二区精品| 一区在线视频| 欧美视频国产精品| 另类亚洲自拍| 亚洲欧洲av一区二区三区久久| 久久人人看视频| 亚洲欧美激情诱惑| 亚洲激情啪啪| 亚洲第一精品夜夜躁人人躁| 欧美日韩在线观看一区二区| 久久精品官网| 亚洲欧美在线视频观看| 一本色道久久综合亚洲精品婷婷| 久久深夜福利免费观看| 亚洲欧美第一页| 亚洲一区二区三区免费观看| 亚洲黄一区二区三区| 在线观看成人网| 伊人婷婷欧美激情| 国产午夜精品理论片a级大结局 | 国产一区二区三区免费在线观看 | 欧美一区二区播放| 亚洲综合精品四区| 中文一区在线| 亚洲制服少妇| 欧美中文字幕视频| 久久综合久久综合久久| 久久精品在线播放| 久久激情五月丁香伊人| 久久亚洲国产成人| 蜜桃av一区二区三区| 久久综合福利| 亚洲日产国产精品| 亚洲视频你懂的| 亚欧成人精品| 欧美va亚洲va香蕉在线| 欧美精品久久久久久久免费观看| 欧美日韩播放| 激情综合久久| 亚洲视频网在线直播| 久久久久久久久综合| 亚洲黄色视屏| 久久国产精品一区二区三区| 暖暖成人免费视频| 狠狠色丁香久久婷婷综合_中| 亚洲精品视频在线| 久久婷婷激情| 亚洲午夜一二三区视频| 久久精品一区二区三区不卡牛牛| 免费一级欧美在线大片| 国产精品久久久久久户外露出| 国产亚洲欧美日韩精品| 亚洲自拍偷拍网址| 亚洲激情午夜| 女生裸体视频一区二区三区| 国产精品第一区| 亚洲一区二区三区免费观看| 免费观看久久久4p| 欧美亚洲一区二区在线观看| 欧美日韩国产天堂| 亚洲视频网站在线观看| 亚洲国产一区二区三区a毛片 | 亚洲欧美在线看| 欧美日韩一区免费| 日韩午夜在线观看视频| 亚洲国产三级| 欧美精品乱码久久久久久按摩| 久久精品亚洲一区| 亚洲第一黄色网| 亚洲国产视频一区| 欧美视频第二页| 亚洲欧美久久久久一区二区三区| 夜夜嗨av一区二区三区网站四季av | 亚洲国产天堂久久国产91| 开元免费观看欧美电视剧网站| 国产一区二区三区久久精品| 久久综合狠狠综合久久综合88| 久久国产精品久久久久久| 一区二区三区自拍| 亚洲茄子视频| 国产美女精品| 亚洲欧洲久久| 狠狠网亚洲精品| 亚洲欧洲一区二区三区在线观看| 欧美激情视频网站| 欧美亚洲一级片| 免费观看成人| 久久综合给合久久狠狠狠97色69| 日韩天堂在线视频| 欧美伊人久久| 亚洲欧美综合v| 欧美国内亚洲| 女人天堂亚洲aⅴ在线观看| 国产精品入口日韩视频大尺度 | 国产一区二区精品久久| aa级大片欧美三级| 亚洲人成网站在线播| 久久综合99re88久久爱| 久久久久久久999精品视频| 欧美日韩精品免费观看视一区二区| 久久激情中文| 精品999网站| 久久人91精品久久久久久不卡| 亚洲一区二区在线视频 | 香蕉久久夜色精品国产| 欧美成人精品在线播放| 美女精品在线| 亚洲国产精品激情在线观看 |