日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > php教程 > 數據結構例程――從根節點到每個葉子節點的路徑之逆

數據結構例程――從根節點到每個葉子節點的路徑之逆

來源:程序員人生   發布時間:2016-02-27 15:46:21 閱讀次數:3159次

本文是數據結構基礎系列(6):樹和2叉樹中第11課時2叉樹遍歷非遞歸算法和第12課時層次遍歷算法的例程。

問題:設計算法輸出從根節點到每一個葉子節點的路徑之逆。
解法1:利用2叉樹后序遍歷非遞歸算法中,每個葉子節點出現時,棧中從棧頂到棧底,正好是葉子節點到根節點的逆序的性質編寫。

[參考解答](btreee.h見算法庫)

#include <stdio.h> #include "btree.h" void AllPath1(BTNode *b) { BTNode *St[MaxSize]; BTNode *p; int flag,i,top=-1; //棧指針置初值 if (b!=NULL) { do { while (b!=NULL) //將*b的所有左節點進棧 { top++; St[top]=b; b=b->lchild; } p=NULL; flag=1; while (top!=-1 && flag) { b=St[top]; //取出當前的棧頂元素 if (b->rchild==p) { if (b->lchild==NULL && b->rchild==NULL) { //若為葉子節點,輸出棧中所有節點值 for (i=top; i>0; i--) printf("%c->",St[i]->data); printf("%c ",St[0]->data); } top--; p=b; //p指向剛訪問過的節點 } else { b=b->rchild; //b指向右孩子節點 flag=0; } } } while (top!=-1); printf(" "); } } int main() { BTNode *b; CreateBTNode(b,"A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))"); printf("2叉樹b: "); DispBTNode(b); printf(" "); printf("從根節點到每一個葉子節點的路徑之逆: "); AllPath1(b); DestroyBTNode(b); return 0; }

解法2:利用2叉樹層次遍歷算法的思路解決。

  • 采取非環形順序隊列qu
  • 層次遍歷2叉樹
  • 將所有已訪問過的節點指針進隊,并在隊列中保存雙親節點的位置。
  • 當找到1個葉子節點時,在隊列中通過雙親節點的位置輸出根節點到該葉子節點的路徑之逆。

[參考解答](btreee.h見算法庫)

#include <stdio.h> #include "btree.h" void AllPath2(BTNode *b) { struct snode { BTNode *node; //寄存當前節點指針 int parent; //寄存雙親節點在隊列中的位置 } qu[MaxSize]; //定義非環形隊列 BTNode *q; int front,rear,p; //定義隊頭和隊尾指針 front=rear=-1; //置隊列為空隊列 rear++; qu[rear].node=b; //根節點指針進入隊列 qu[rear].parent=-1; //根節點沒有雙親節點 while (front!=rear) //隊列不為空 { front++; //front是當前節點*q在qu中的位置 q=qu[front].node; //隊頭出隊列,該節點指針仍在qu中 if (q->lchild==NULL && q->rchild==NULL) { p=front; //輸出*q到根節點的路徑序列 while (qu[p].parent!=-1) { printf("%c->",qu[p].node->data); p=qu[p].parent; } printf("%c ",qu[p].node->data); } if (q->lchild!=NULL) //*q節點有左孩子時將其進列 { rear++; qu[rear].node=q->lchild; qu[rear].parent=front; //*q的雙親位置為front } if (q->rchild!=NULL) //*q節點有右孩子時將其進列 { rear++; qu[rear].node=q->rchild; qu[rear].parent=front; //*q的雙親位置為front } } } int main() { BTNode *b; CreateBTNode(b,"A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))"); printf("2叉樹b: "); DispBTNode(b); printf(" "); printf("從根節點到每一個葉子節點的路徑之逆: "); AllPath2(b); DestroyBTNode(b); return 0; }

注:在main函數中,創建的用于測試的2叉樹以下――
這里寫圖片描述

版權聲明:本文為博主原創文章,未經博主允許不得轉載。

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 日韩精品免费 | 欧美九九| 国产成人午夜视频 | 精品一区久久 | 国产激情美女久久久久久吹潮 | 国产激情 | 日韩精品一区二区三区四区 | 免费视频一区 | 国产91视频在线 | 免费久久久久久久 | 久久久久久久久综合 | 久久av网| 久久成人国产 | 福利片在线 | 日韩影院在线 | h黄视频| 91香蕉视频污污 | 激情婷婷 | 在线视频h| www.日韩| 国产精品av在线 | 精品久久久久久国产 | a免费在线观看 | 亚洲国产精品久久人人爱 | 国产精品成人在线 | 91精品国产综合久久久久久蜜臀 | 国产精品xxx在线观看www | h片在线免费观看 | 毛片基地黄久久久久久天堂 | 久久久久一区二区三区 | 麻豆久久久久久 | 99精品视频免费观看 | 伊人9| 久成人 | 日韩精品中文字幕在线 | 久久久a | 福利片网站 | 国产一区久久 | 国产免费一级片 | 亚洲一区二区在线视频 | 国产精品久久久久久久久久久久久 |