Java實(shí)現(xiàn)求二叉樹的深度和寬度
這個是常見的對二叉樹的操作??偨Y(jié)一下:
設(shè)節(jié)點(diǎn)的數(shù)據(jù)結(jié)構(gòu),如下:
class TreeNode {
char val;
TreeNode left = null;
TreeNode right = null;
TreeNode(char _val) {
this.val = _val;
}
}
1.二叉樹深度
這個可以使用遞歸,分別求出左子樹的深度、右子樹的深度,兩個深度的較大值+1即可。
// 獲取最大深度
public static int getMaxDepth(TreeNode root) {
if (root == null)
return 0;
else {
int left = getMaxDepth(root.left);
int right = getMaxDepth(root.right);
return 1 + Math.max(left, right);
}
}
2.二叉樹寬度
使用隊(duì)列,層次遍歷二叉樹。在上一層遍歷完成后,下一層的所有節(jié)點(diǎn)已經(jīng)放到隊(duì)列中,此時隊(duì)列中的元素個數(shù)就是下一層的寬度。以此類推,依次遍歷下一層即可求出二叉樹的最大寬度。
// 獲取最大寬度
public static int getMaxWidth(TreeNode root) {
if (root == null)
return 0;
Queue<TreeNode> queue = new ArrayDeque<TreeNode>();
int maxWitdth = 1; // 最大寬度
queue.add(root); // 入隊(duì)
while (true) {
int len = queue.size(); // 當(dāng)前層的節(jié)點(diǎn)個數(shù)
if (len == 0)
break;
while (len > 0) {// 如果當(dāng)前層,還有節(jié)點(diǎn)
TreeNode t = queue.poll();
len--;
if (t.left != null)
queue.add(t.left); // 下一層節(jié)點(diǎn)入隊(duì)
if (t.right != null)
queue.add(t.right);// 下一層節(jié)點(diǎn)入隊(duì)
}
maxWitdth = Math.max(maxWitdth, queue.size());
}
return maxWitdth;
}
- 圖解二叉樹的三種遍歷方式及java實(shí)現(xiàn)代碼
- 圖解紅黑樹及Java進(jìn)行紅黑二叉樹遍歷的方法
- java實(shí)現(xiàn)二叉樹的創(chuàng)建及5種遍歷方法(總結(jié))
- Java實(shí)現(xiàn)二叉樹的深度優(yōu)先遍歷和廣度優(yōu)先遍歷算法示例
- Java中二叉樹數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)示例
- Java實(shí)現(xiàn)打印二叉樹所有路徑的方法
- java使用歸并刪除法刪除二叉樹中節(jié)點(diǎn)的方法
- JAVA 實(shí)現(xiàn)二叉樹(鏈?zhǔn)酱鎯Y(jié)構(gòu))
- java實(shí)現(xiàn)二叉樹遍歷的三種方式
- 一篇文章徹底弄懂Java中二叉樹
相關(guān)文章
JMeter連接Mysql數(shù)據(jù)庫的實(shí)現(xiàn)步驟
本文主要介紹了JMeter操作Mysql數(shù)據(jù)庫,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12
springboot docker原理及項(xiàng)目構(gòu)建
這篇文章主要介紹了springboot docker原理及項(xiàng)目構(gòu)建,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-11-11
Future與FutureTask接口實(shí)現(xiàn)示例詳解
這篇文章主要為大家介紹了Future與FutureTask接口實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
基于Springboot的漫畫網(wǎng)站平臺設(shè)計(jì)與實(shí)現(xiàn)
本文將基于Springboot實(shí)現(xiàn)開發(fā)一個漫畫主題的網(wǎng)站,實(shí)現(xiàn)一個比漂亮的動漫連載的網(wǎng)站系統(tǒng),界面設(shè)計(jì)優(yōu)雅大方,比較適合做畢業(yè)設(shè)計(jì)和課程設(shè)計(jì)使用,需要的可以參考一下2022-08-08
java如何將Object數(shù)組轉(zhuǎn)換為指定類型數(shù)組
這篇文章主要介紹了java如何將Object數(shù)組轉(zhuǎn)換為指定類型數(shù)組,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08
Java實(shí)現(xiàn)的讀取資源文件工具類ResourcesUtil實(shí)例【可動態(tài)更改值的內(nèi)容】
這篇文章主要介紹了Java實(shí)現(xiàn)的讀取資源文件工具類ResourcesUtil,結(jié)合實(shí)例形式分析了java針對資源文件的讀取與修改相關(guān)操作技巧,需要的朋友可以參考下2017-10-10
IDEA的spring項(xiàng)目使用@Qualifier飄紅問題及解決
這篇文章主要介紹了IDEA的spring項(xiàng)目使用@Qualifier飄紅問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11
Java運(yùn)行時數(shù)據(jù)區(qū)概述詳解
這篇文章主要介紹了Java運(yùn)行時數(shù)據(jù)區(qū)概述,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03

