題目描述有一個(gè)?n(n \le 10^6)n(n≤106)?個(gè)結(jié)點(diǎn)的二叉樹。給出每個(gè)結(jié)點(diǎn)的兩個(gè)子結(jié)點(diǎn)編號(均不超過?nn),建立一棵二叉樹(根節(jié)點(diǎn)的編號為?11),如果是葉子結(jié)點(diǎn),則輸入?
10多年的丁青網(wǎng)站建設(shè)經(jīng)驗(yàn),針對設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。成都全網(wǎng)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整丁青建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)公司從事“丁青網(wǎng)站設(shè)計(jì)”,“丁青網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。0 0
。建好這棵二叉樹之后,請求出它的深度。二叉樹的深度是指從根節(jié)點(diǎn)到葉子結(jié)點(diǎn)時(shí),最多經(jīng)過了幾層。
輸入格式第一行一個(gè)整數(shù)?nn,表示結(jié)點(diǎn)數(shù)。
之后?nn?行,第?ii?行兩個(gè)整數(shù)?ll、rr,分別表示結(jié)點(diǎn)?ii?的左右子結(jié)點(diǎn)編號。若?l=0l=0?則表示無左子結(jié)點(diǎn),r=0r=0?同理。
輸出格式一個(gè)整數(shù),表示大結(jié)點(diǎn)深度。
輸入輸出樣例輸入 #1復(fù)制
7 2 7 3 6 4 5 0 0 0 0 0 0 0 0輸出 #1復(fù)制
4
1.這道題,去創(chuàng)建二叉樹去做的話,是比較麻煩的,用dfs可以。
2.這道題之所以用dfs,是因?yàn)樗斎氲臄?shù)據(jù)適合使用dfs,這個(gè)題目的意思一定要搞明白,之前就是搞不明白,然后大眼瞪小眼看了一下午沒明白。
這道題說的是??第?i行兩個(gè)整數(shù)?l、r,分別表示結(jié)點(diǎn)?i的左右子結(jié)點(diǎn)編號。
以下面這道題目為列子:
創(chuàng)建出來的二叉樹:
這里是不計(jì)算 0 的節(jié)點(diǎn)的。所以是很適合使用dfs的。
我們可以先把節(jié)點(diǎn)記下來,在一個(gè)結(jié)構(gòu)體中。
然后使用 dfs的方式去使用就可以,因?yàn)閐fs的特點(diǎn)是不撞南墻不回頭,當(dāng)它遇到0時(shí),我們結(jié)束即可。從根節(jié)點(diǎn)開始遞歸,分別遞歸左右子樹,即可。
代碼如下:(C語言)
#include#define N 1000010
struct node
{
int l;
int r;
}a[N];
int max;
int dfs(int x,int step)
{
if(x==0)
{
if(max
c++代碼:
#include#includeusing namespace std;
const int N = 1e6 + 10;
struct node
{
int l;
int r;
} a[N];
int maxstep;
int dfs(int x, int step)
{
if (x == 0)
{
if (maxstep< step) maxstep = step;
return 0;
}
dfs(a[x].l, step + 1);
dfs(a[x].r, step + 1);
}
int main()
{
int n;
scanf("%d", &n);
for (int i = 1; i<= n; i++)
{
cin >>a[i].l >>a[i].r;
}
dfs(1, 0);
cout<< maxstep<< endl;
return 0;
}
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級服務(wù)器適合批量采購,新人活動(dòng)首月15元起,快前往官網(wǎng)查看詳情吧
分享名稱:P4913【深基16.例3】二叉樹深度-創(chuàng)新互聯(lián)
標(biāo)題URL:http://jinyejixie.com/article32/dsigsc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、小程序開發(fā)、網(wǎng)站排名、服務(wù)器托管、網(wǎng)站設(shè)計(jì)、全網(wǎng)營銷推廣
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容