日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

二叉树的操作4

發布時間:2023/12/15 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 二叉树的操作4 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

【路徑問題】

問題描述:采用先序遍歷方法輸出所有從葉子結點到根結點的逆路徑。

二叉樹 b:A(B(D,E(H(J,K(L,M(,N))))),C(F,G(,I)))

先序遍歷方法:

D 到根結點逆路徑: D->B->A

J 到根結點逆路徑: J->H->E->B->A

L 到根結點逆路徑: L->K->H->E->B->A

N 到根結點逆路徑: N->M->K->H->E->B->A
F 到根結點逆路徑: F->C->A

I 到根結點逆路徑: I->G->C->A

第一條最長逆路徑長度:7

第一條最長逆路徑:N M K H E B A

dfs和bfs都可以輸出路徑,但是二者也有所不同。bfs主要是隊列,先進先出。而dfs則可以回來,用一個數組存儲就可以了。寫這個題目的時候,我想到了深搜的入門題,素數環。。可以來參考一下
代碼如下:

#include<bits/stdc++.h> using namespace std;typedef struct node{char data;struct node *lchild;struct node *rchild;int vis; } *Bitree;void creatree(Bitree &t) {char c;cin>>c;if(c=='#') t=NULL;else{t=(node *)malloc(sizeof(node));t->data=c;t->vis=0;creatree(t->lchild);creatree(t->rchild);} }char s[1010]; char s1[1010]; int cnt=0; int maxx=-1;void dfs(Bitree &t) {if(t!=NULL){s[cnt++]=t->data;if(t->lchild==NULL&&t->rchild==NULL){printf("從%c到%c的路徑為:\n",s[cnt-1],s[0]);for(int i=cnt-1;i>=0;i--){cout<<s[i];if(i) cout<<"->";}if(maxx<cnt){maxx=cnt;strcpy(s1,s);}cnt--;//cnt為全局變量,在這里需要減一。cout<<endl;return ;}dfs(t->lchild);dfs(t->rchild);cnt--;//當一個節點以下的走完了以后,就cnt--,去找尋上面的節點、} }int main() {Bitree t;creatree(t); dfs(t);cout<<"第一條最長逆路徑長度:"<<maxx<<endl;for(int i=maxx-1;i>=0;i--) cout<<s1[i]<<" "; } //ABD##EHJ##KL##M#N###CF##G#I##

努力加油a啊,(o)/~

總結

以上是生活随笔為你收集整理的二叉树的操作4的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。