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

woaidongmao

文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
數據加載中……

精典二叉樹非遞歸遍歷的算法

遍歷二叉樹的非遞歸算法
編寫的方法:根據樹中結點的遍歷規律及順序直接寫出其非遞歸算法。
先序非遞歸算法
【思路】
假設:T是要遍歷樹的根指針,若T != NULL
對于非遞歸算法,引入棧模擬遞歸工作棧,初始時棧為空。
問題:如何用棧來保存信息,使得在先序遍歷過左子樹后,能利用棧頂信息獲取T的右子樹的根指針?
方法1:訪問T->data后,將T入棧,遍歷左子樹;遍歷完左子樹返回時,棧頂元素應為T,出棧,再先序遍歷T的右子樹。
方法2:訪問T->data后,將T->rchild入棧,遍歷左子樹;遍歷完左子樹返回時,棧頂元素應為T->rchild,出棧,遍歷以該指針為根的子樹。
【算法1
void    PreOrder(BiTree T, Status ( *Visit ) (ElemType e))

{    //
基于方法一,流程圖如右,當型循環
InitStack(S);
while ( T!=NULL || !StackEmpty(S)){
while ( T != NULL ){
Visit(T->data) ;
Push(S,T);
T = T->lchild;
}
if( !StackEmpty(S) ){
Pop(S,T);
T = T->rchild;
}
}
}
【算法2
void    PreOrder(BiTree T, Status ( *Visit ) (ElemType e))

{    //
基于方法二,流程圖如右,當型循環
InitStack(S);
while ( T!=NULL || !StackEmpty(S) ){
while ( T != NULL ){
Visit(T->data);
Push(S, T->rchild);
T = T->lchild;
}
if ( !StackEmpty(S) ){
Pop(S,T);
}
}
}
進一步考慮:對于處理流程中的循環體的直到型、當型+直到型的實現。
中序非遞歸算法
【思路】
T
是要遍歷樹的根指針,中序遍歷要求在遍歷完左子樹后,訪問根,再遍歷右子樹。
問題:如何用棧來保存信息,使得在中序遍歷過左子樹后,能利用棧頂信息獲取T指針?
方法:先將T入棧,遍歷左子樹;遍歷完左子樹返回時,棧頂元素應為T,出棧,訪問T->data,再中序遍歷T的右子樹。

【算法】
void    InOrder(BiTree T, Status ( *Visit ) (ElemType e))
{    //
流程圖如右,當型循環
InitStack(S);
while ( T!=NULL || !StackEmpty(S) ){
while ( T != NULL ){
Push(S,T);
T = T->lchild;
}
if( !StackEmpty(S) ){
Pop(S, T);
Visit(T->data);
T = T->rchild;
}
}
}
進一步考慮:對于處理流程中的循環體的直到型、當型+直到型的實現。
后序非遞歸算法
【思路】

T
是要遍歷樹的根指針,后序遍歷要求在遍歷完左右子樹后,再訪問根。需要判斷根結點的左右子樹是否均遍歷過。
可采用標記法,結點入棧時,配一個標志tag一同入棧(0:遍歷左子樹前的現場保護,1:遍歷右子樹前的現場保護)
首先將Ttag(0)入棧,遍歷左子樹;返回后,修改棧頂tag1,遍歷右子樹;最后訪問根結點。
typedef struct stackElement{
Bitree    data;
char        tag;
}stackElemType;
【算法】
void    PostOrder(BiTree T, Status ( *Visit ) (ElemType e))
{    //
流程圖如右,當型循環
InitStack(S);
while ( T!=NULL || !StackEmpty(S) ){
while ( T != NULL ){
Push(S,T,0);
T = T->lchild;
}
while ( !StackEmpty(S) && GetTopTag(S)==1){
Pop(S, T);
Visit(T->data);
}
if ( !StackEmpty(S) ){
SetTopTag(S, 1);        //
設置棧頂標記
T = GetTopPointer(S);    //
取棧頂保存的指針
T = T->rchild;
}else break;
}
}

 

posted on 2009-10-10 15:00 肥仔 閱讀(1491) 評論(0)  編輯 收藏 引用 所屬分類: 數據結構 & 算法


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美aⅴ一区二区三区视频| 美女精品网站| 在线欧美日韩精品| 亚洲国产日韩欧美在线动漫| 亚洲电影中文字幕| 亚洲人精品午夜在线观看| 99在线热播精品免费| 久久精品系列| 欧美电影免费观看大全| 欧美久久99| 国产精品羞羞答答| 国产欧美日韩高清| 在线免费观看一区二区三区| 一本色道久久综合狠狠躁的推荐| 亚洲欧美国产日韩中文字幕| 久久婷婷久久一区二区三区| 亚洲国产日韩欧美在线99| 99pao成人国产永久免费视频| 亚洲女人av| 欧美激情成人在线视频| 国产人久久人人人人爽| 亚洲精品一区在线观看| 久久爱另类一区二区小说| 亚洲经典视频在线观看| 欧美一区二区免费| 欧美日韩一区二区三区视频| 国产主播在线一区| 在线视频一区二区| 欧美黑人多人双交| 亚洲欧美第一页| 欧美日本在线播放| 永久久久久久| 久久精品国产精品亚洲| 亚洲精品日韩精品| 久久久午夜视频| 国产精品一区免费视频| 99视频一区二区三区| 老司机免费视频久久| 亚洲午夜免费视频| 欧美精品999| 亚洲欧洲日本一区二区三区| 久久国产精品黑丝| 亚洲午夜免费福利视频| 欧美久久影院| 亚洲欧洲美洲综合色网| 蜜乳av另类精品一区二区| 亚洲毛片一区二区| 欧美激情精品久久久久久| 亚洲国产精品激情在线观看| 久久免费国产| 午夜一区不卡| 国产欧美一区二区三区在线老狼 | 欧美成人激情在线| 国语自产精品视频在线看一大j8 | 亚洲一区国产精品| 亚洲视频在线看| 欧美激情欧美激情在线五月| 久久se精品一区二区| 国产精品中文在线| 欧美在线视频免费观看| 亚洲欧美影院| 国产一区二区三区不卡在线观看 | 久久综合电影一区| 韩日精品中文字幕| 久久综合图片| 久久在线视频在线| 亚洲激情精品| 亚洲区欧美区| 国产精品扒开腿做爽爽爽视频| 一区二区三区日韩在线观看| 99精品视频免费观看视频| 欧美体内she精视频| 午夜宅男欧美| 久久精品网址| 亚洲日本va午夜在线电影 | 亚洲精品久久| 欧美视频久久| 久久久精品动漫| 久久综合网络一区二区| 最新亚洲电影| 亚洲一级电影| 亚洲国产mv| 日韩亚洲一区在线播放| 国产女同一区二区| 欧美 日韩 国产在线| 欧美成人精精品一区二区频| 中国日韩欧美久久久久久久久| 亚洲一区二区精品在线| 伊人蜜桃色噜噜激情综合| 亚洲区第一页| 国产一区二区三区电影在线观看| 欧美a级片网| 国产精品毛片va一区二区三区| 久久久蜜桃一区二区人| 欧美精品二区| 久久久久久久久岛国免费| 欧美国产精品va在线观看| 欧美一区二区三区视频免费播放| 久久九九热免费视频| 正在播放亚洲一区| 久久久久久久久久久久久女国产乱| 亚洲精品久久久久| 午夜亚洲性色视频| 一区二区三区你懂的| 久久久久久一区| 午夜精品福利在线观看| 欧美福利精品| 久久综合久久综合久久| 欧美日韩一区高清| 亚洲高清不卡一区| 精品91久久久久| 亚洲欧美日韩国产中文| 亚洲最新在线| 欧美成人一区在线| 在线国产欧美| 一区二区三区视频观看| 亚洲精品欧美| 久久久7777| 久久精品国产第一区二区三区最新章节| 欧美另类变人与禽xxxxx| 欧美jjzz| 激情欧美国产欧美| 欧美一区二区精美| 久久高清免费观看| 国产精品视频你懂的| 亚洲精品美女久久久久| 亚洲日本欧美| 欧美sm极限捆绑bd| 亚洲第一久久影院| 亚洲国产成人av好男人在线观看| 欧美一级在线播放| 久久精品人人做人人综合| 国产美女扒开尿口久久久| 亚洲免费一在线| 久久精品2019中文字幕| 国产性色一区二区| 久久精品国产一区二区三区| 久久久久久国产精品一区| 国产三级欧美三级| 欧美一区二区视频在线观看| 久久精品国产免费观看| 国产亚洲成av人在线观看导航| 亚洲综合国产精品| 久久精品亚洲国产奇米99| 国产一区在线看| 久久精品国产第一区二区三区最新章节| 欧美一级久久久| 国内在线观看一区二区三区| 久久九九国产精品怡红院| 男人的天堂亚洲| 亚洲精品久久视频| 欧美视频中文字幕| 亚洲欧美日韩精品久久久| 久久九九精品| 亚洲经典一区| 国产精品a久久久久久| 午夜精品美女自拍福到在线 | 欧美日韩国产欧美日美国产精品| 日韩一区二区精品葵司在线| 羞羞漫画18久久大片| 黄色一区二区在线| 免费永久网站黄欧美| 亚洲最黄网站| 久久精品麻豆| aaa亚洲精品一二三区| 国产伦精品一区二区三区免费迷| 久久精品久久99精品久久| 亚洲人体一区| 久久精品国产96久久久香蕉| 亚洲激情校园春色| 国产精品视频免费| 老司机aⅴ在线精品导航| 在线视频精品一| 可以免费看不卡的av网站| 中文成人激情娱乐网| 激情成人在线视频| 欧美无乱码久久久免费午夜一区| 久久九九精品| 中文亚洲欧美| 亚洲电影在线| 久久精品国产综合精品| 一二三四社区欧美黄| 国产在线观看精品一区二区三区| 亚洲一区网站| 欧美成人日韩| 久久狠狠久久综合桃花| 99热在线精品观看| 伊人蜜桃色噜噜激情综合| 国产精品久久波多野结衣| 蜜臀久久99精品久久久久久9| 亚洲一区三区在线观看| 亚洲精品日韩欧美| 欧美3dxxxxhd| 久久久午夜电影| 小处雏高清一区二区三区 | 久久影院午夜片一区| 亚洲男人第一网站| 亚洲精品专区| 亚洲国产精品国自产拍av秋霞| 国产亚洲精品aa午夜观看|