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

二叉樹前序,中序,后序遍歷的非遞歸實現(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>
            国产精品v亚洲精品v日韩精品| 欧美岛国在线观看| 国产精品久线观看视频| 欧美日韩精品三区| 欧美精品一区在线| 欧美日韩在线一区二区| 国产精品爱啪在线线免费观看| 欧美日韩国产一区二区| 欧美精品一区二区三区久久久竹菊| 欧美a级大片| 国产精品成人在线| 国模一区二区三区| 亚洲国产日韩综合一区| 洋洋av久久久久久久一区| 亚洲自啪免费| 老司机久久99久久精品播放免费| 免费日韩av| 99综合在线| 久久国产精品网站| 欧美日韩视频不卡| 精品成人在线视频| 亚洲一本视频| 欧美高清视频在线播放| 一区二区三区www| 久久久国产精品亚洲一区 | 亚洲欧美久久| 久久久久一本一区二区青青蜜月| 欧美多人爱爱视频网站| 亚洲欧美另类在线| 欧美连裤袜在线视频| 国产在线观看精品一区二区三区 | 久久免费视频网| 国产精品国产成人国产三级| 伊人影院久久| 久久久精品五月天| 亚洲午夜高清视频| 欧美另类视频| 日韩午夜免费| 一区二区三区在线看| 一本大道久久a久久精品综合| 久久精品视频在线播放| 国产精品99久久久久久久久久久久 | 亚洲乱码国产乱码精品精天堂| 久久av最新网址| 亚洲天堂视频在线观看| 欧美美女bb生活片| 亚洲第一视频网站| 久久久夜色精品亚洲| 亚洲免费视频中文字幕| 欧美亚洲不卡| 亚洲伊人一本大道中文字幕| 亚洲日本aⅴ片在线观看香蕉| 欧美在线视频在线播放完整版免费观看| 欧美日韩一区二区三区免费| 亚洲人成77777在线观看网| 老司机午夜精品视频在线观看| 亚洲女性裸体视频| 国产麻豆午夜三级精品| 亚洲欧洲av一区二区| 亚洲午夜电影| 黑人巨大精品欧美黑白配亚洲| 久久久中精品2020中文| 久久精品人人| 亚洲国产日韩欧美在线图片| 欧美jjzz| 欧美日韩免费高清| 性欧美超级视频| 久久国产欧美日韩精品| 伊人成人网在线看| 91久久精品国产91久久性色tv | 午夜久久tv| 亚洲综合色丁香婷婷六月图片| 国产欧美一区二区三区久久人妖| 欧美一级成年大片在线观看| 亚洲欧美日韩第一区| 狠狠干成人综合网| 亚洲高清一区二区三区| 欧美日韩国产高清视频| 亚洲综合三区| 久久精品一二三区| 99精品国产一区二区青青牛奶| 洋洋av久久久久久久一区| 国产精品一区二区在线观看不卡 | 一区二区三区在线免费观看| 蜜桃av综合| 欧美日韩精品综合| 久久久久久穴| 欧美激情网友自拍| 欧美在线91| 欧美高清成人| 久久精品视频导航| 久久人人爽人人爽爽久久| 久久手机免费观看| 欧美激情第1页| 亚洲欧美日韩精品久久久| 久久高清福利视频| 99精品久久| 欧美一级日韩一级| 99热免费精品在线观看| 午夜精品久久久久久久| 亚洲精品视频一区| 欧美在线视频免费观看| 一区二区免费在线播放| 欧美中在线观看| 亚洲性av在线| 欧美不卡视频| 久久色中文字幕| 国产精品视频yy9099| 亚洲黄色影院| 伊人影院久久| 性视频1819p久久| 亚洲在线免费观看| 欧美国产精品劲爆| 蜜桃av一区二区三区| 国产免费观看久久| 亚洲最新在线| 一区二区三区蜜桃网| 蜜桃av一区| 蜜臀久久99精品久久久画质超高清| 国产精品电影在线观看| 亚洲激情视频网站| 亚洲国产激情| 久久婷婷亚洲| 美女黄毛**国产精品啪啪| 国产日韩av一区二区| 一区二区三区欧美亚洲| 一本到高清视频免费精品| 欧美成人免费在线观看| 女人天堂亚洲aⅴ在线观看| 国产有码在线一区二区视频| 亚洲在线播放| 欧美影院成人| 国产一区二区成人| 久久av一区| 鲁大师成人一区二区三区| 国内一区二区三区| 久久蜜桃精品| 欧美激情第六页| 亚洲美女网站| 欧美日韩中文字幕在线| 这里只有精品电影| 欧美一区二区播放| 国产欧美亚洲一区| 久久精品一区二区三区四区| 美女国内精品自产拍在线播放| 亚洲国产精品久久精品怡红院| 欧美不卡视频一区| 9人人澡人人爽人人精品| 午夜精品久久久久久久99黑人| 国产精品美女久久久浪潮软件| 亚洲在线观看视频网站| 久久精品亚洲| 亚洲人成人一区二区在线观看 | 国产精品人人爽人人做我的可爱 | 影音先锋日韩有码| 99re8这里有精品热视频免费| 亚洲第一二三四五区| 91久久久久久久久| 欧美日韩中文字幕综合视频| 中文欧美日韩| 久久夜色精品国产亚洲aⅴ| 亚洲第一页自拍| 欧美日韩一区二区三区| 欧美一级一区| 亚洲精品国产精品国自产观看浪潮 | 欧美超级免费视 在线| 亚洲美女精品一区| 欧美一区二区三区视频免费播放| 韩日视频一区| 欧美日韩亚洲三区| 久久久久久久久蜜桃| 亚洲美女色禁图| 久久视频在线视频| 亚洲图片自拍偷拍| 亚洲成人在线免费| 国产精品日本| 欧美国产日韩一区| 欧美一区久久| 一本大道久久a久久精品综合| 美女黄网久久| 欧美亚洲一区二区在线| 亚洲欧洲精品天堂一级 | 在线视频日韩精品| 狠狠色综合色综合网络| 欧美日韩色一区| 久久综合久久88| 性做久久久久久免费观看欧美| 欧美韩国日本一区| 久久精品国产一区二区三区| 99国产精品国产精品久久| 黄色一区二区三区| 国产老女人精品毛片久久| 欧美精品在线播放| 久久一区二区三区超碰国产精品| 亚洲一区二区黄色| 亚洲裸体视频| 亚洲精品一区中文| 最近看过的日韩成人| 欧美电影专区| 欧美aaa级|