Java語(yǔ)言描述二叉樹的深度和寬度
解釋:
二叉樹的深度:從根結(jié)點(diǎn)到葉結(jié)點(diǎn)依次經(jīng)過的結(jié)點(diǎn)(含根、葉結(jié)點(diǎn))形成樹的一條路徑,最長(zhǎng)路徑的長(zhǎng)度為樹的深度。
二叉樹的寬度:二叉樹的每一層中都有一定數(shù)量的節(jié)點(diǎn),節(jié)點(diǎn)數(shù)最多的那一層的節(jié)點(diǎn)數(shù)叫做二叉樹的寬度。
思路:遞歸實(shí)現(xiàn)。
1.每個(gè)節(jié)點(diǎn)都可以看作根節(jié)點(diǎn)
2.根節(jié)點(diǎn)(任意一個(gè)節(jié)點(diǎn))的深度等于它的左子樹或右子樹深度最大值+1
3.從根結(jié)點(diǎn)開始遍歷,若遍歷到葉子節(jié)點(diǎn),深度為0
//二叉樹的深度
public static int Depth(node root){
if(root == null){
return 0;
}
int dl = Depth(root.leftchild);
int dr = Depth(root.rightchild);
return dl>dr? dl+1:dr+1;
}
二、二叉樹的寬度
思路:層序遍歷時(shí)添加一個(gè)計(jì)數(shù)器,記錄每層的節(jié)點(diǎn)數(shù)
1.每層出隊(duì)列時(shí)記錄下一層的節(jié)點(diǎn)數(shù),其實(shí)就是隊(duì)列的Size()
2.每層遍歷結(jié)束時(shí),比較最大寬度與當(dāng)前層節(jié)點(diǎn)數(shù),記錄最大值
public static int Width(node root) {
if(root == null)
return 0;
Queue<node> q = new LinkedList<node>();
q.add(root);
int width = 1;
//最大寬度
int len = 1;
//當(dāng)前層節(jié)點(diǎn)數(shù)
while(q.size()>0){
while(len-->0){
node node = q.poll();
if(node.leftchild != null){
q.add(node.leftchild);
}
if(node.rightchild != null){
q.add(node.rightchild);
}
}
len = q.size();
//每層循環(huán)結(jié)束后記錄下一層的節(jié)點(diǎn)數(shù)
width = width>q.size() ? width : q.size();
}
return width;
}
總結(jié)
以上就是本文關(guān)于Java語(yǔ)言描述二叉樹的深度和寬度的全部?jī)?nèi)容,希望對(duì)大家有所幫助。如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!
- java實(shí)現(xiàn)二叉樹的創(chuàng)建及5種遍歷方法(總結(jié))
- Java實(shí)現(xiàn)求二叉樹的深度和寬度
- java使用歸并刪除法刪除二叉樹中節(jié)點(diǎn)的方法
- Java實(shí)現(xiàn)二叉樹的深度優(yōu)先遍歷和廣度優(yōu)先遍歷算法示例
- Java實(shí)現(xiàn)打印二叉樹所有路徑的方法
- Java的二叉樹排序以及遍歷文件展示文本格式的文件樹
- Java實(shí)現(xiàn)的二叉樹常用操作【前序建樹,前中后遞歸非遞歸遍歷及層序遍歷】
- java編程求二叉樹最大路徑問題代碼分析
- Java完全二叉樹的創(chuàng)建與四種遍歷方法分析
- Java中二叉樹的建立和各種遍歷實(shí)例代碼
- Java實(shí)現(xiàn)二叉樹的建立、計(jì)算高度與遞歸輸出操作示例
相關(guān)文章
java中將漢字轉(zhuǎn)換成拼音的實(shí)現(xiàn)代碼
java中將漢字轉(zhuǎn)換成拼音的實(shí)現(xiàn)代碼。需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-10-10
Mybatis-config.xml中映射Mapper.xml文件遇到的錯(cuò)誤及解決
這篇文章主要介紹了Mybatis-config.xml中映射Mapper.xml文件遇到的錯(cuò)誤及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06
java swing實(shí)現(xiàn)貪吃蛇雙人游戲
這篇文章主要為大家詳細(xì)介紹了java swing實(shí)現(xiàn)貪吃蛇雙人小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-01-01
springboot項(xiàng)目或其他項(xiàng)目使用@Test測(cè)試項(xiàng)目接口配置
這篇文章主要介紹了springboot項(xiàng)目或其他項(xiàng)目使用@Test測(cè)試項(xiàng)目接口配置,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
springboot實(shí)現(xiàn)token驗(yàn)證登陸狀態(tài)的示例代碼
本文主要介紹了spring?boot?實(shí)現(xiàn)token驗(yàn)證登陸狀態(tài),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07
自定義spring mvc的json視圖實(shí)現(xiàn)思路解析
這篇文章主要介紹了自定義spring mvc的json視圖的實(shí)現(xiàn)思路解析,本文給大家介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-12-12

