91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java語言描述二叉樹的深度和寬度

發布時間:2020-10-04 15:26:26 來源:腳本之家 閱讀:183 作者:babylove_BaLe 欄目:編程語言

解釋:

二叉樹的深度:從根結點到葉結點依次經過的結點(含根、葉結點)形成樹的一條路徑,最長路徑的長度為樹的深度。
二叉樹的寬度:二叉樹的每一層中都有一定數量的節點,節點數最多的那一層的節點數叫做二叉樹的寬度。

思路:遞歸實現。

1.每個節點都可以看作根節點
2.根節點(任意一個節點)的深度等于它的左子樹或右子樹深度最大值+1
3.從根結點開始遍歷,若遍歷到葉子節點,深度為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;
  }

二、二叉樹的寬度

思路:層序遍歷時添加一個計數器,記錄每層的節點數

1.每層出隊列時記錄下一層的節點數,其實就是隊列的Size()
2.每層遍歷結束時,比較最大寬度與當前層節點數,記錄最大值

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;
	//當前層節點數
	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();
		//每層循環結束后記錄下一層的節點數
		width = width>q.size() ? width : q.size();
	}
	return width;
}

總結

以上就是本文關于Java語言描述二叉樹的深度和寬度的全部內容,希望對大家有所幫助。如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

定兴县| 清水县| 屏东市| 牡丹江市| 通江县| 澄江县| 石阡县| 监利县| 拉萨市| 信宜市| 扶沟县| 宝山区| 酉阳| 江都市| 剑川县| 崇明县| 杂多县| 桦川县| 湛江市| 肃北| 泽普县| 兰溪市| 邵武市| 鄢陵县| 班玛县| 思茅市| 乌鲁木齐市| 汉寿县| 伊川县| 苏尼特左旗| 胶州市| 舟山市| 伊吾县| 宁远县| 鄂托克前旗| 泗阳县| 旬阳县| 吴川市| 承德县| 五指山市| 汉寿县|