LeetCode-543 二叉樹的直徑

題目描述

給定一棵二叉樹撒妈,你需要計算它的直徑長度指孤。一棵二叉樹的直徑長度是任意兩個結點路徑長度中的最大值孵班。這條路徑可能穿過根結點绝葡。

示例 :
給定二叉樹

1
/ \
2 3
/ \
4 5
返回 3, 它的長度是路徑 [4,2,1,3] 或者 [5,2,1,3]鄙漏。

注意:兩結點之間的路徑長度是以它們之間邊的數(shù)目表示嗤谚。

解題思路

利用遞歸的思路,從根節(jié)點開始怔蚌,計算每個節(jié)點的高度:等于左右孩子節(jié)點的高度的最大值加1巩步。
任意一條路徑可以被寫成兩個 箭頭(不同方向),每個箭頭代表一條從某些點向下遍歷到孩子節(jié)點的路徑桦踊。
假設我們知道對于每個節(jié)點最長箭頭距離分別為 L, R椅野,那么最優(yōu)路徑經過 L + R + 1 個節(jié)點。
算法
按照常用方法計算一個節(jié)點的深度:max(depth of node.left, depth of node.right) + 1籍胯。在計算的同時竟闪,經過這個節(jié)點的路徑長度為 1 + (depth of node.left) + (depth of node.right) 。搜索每個節(jié)點并記錄這些路徑經過的點數(shù)最大值杖狼,期望長度是結果 - 1炼蛤。

代碼實現(xiàn)

// C++版本
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    int maxDepth(TreeNode* node, int& ans) {
        if (node == nullptr) return 0;
        int L = maxDepth(node->left, ans);
        int R = maxDepth(node->right, ans);
        ans = max(ans, L+R+1);
        return max(L, R)+1;
    }
    int diameterOfBinaryTree(TreeNode* root) {
        int ans = 1;
        maxDepth(root, ans);
        return ans-1;
    }
};
# python版本
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution:
    def diameterOfBinaryTree(self, root: TreeNode) -> int:
        self.res = 1
        def maxDepth(node):
            if node == None:
                return 0
            L = maxDepth(node.left)
            R = maxDepth(node.right)
            self.res = max(self.res, L+R+1)
            return max(L, R) + 1
        maxDepth(root)
        return self.res - 1

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市蝶涩,隨后出現(xiàn)的幾起案子理朋,更是在濱河造成了極大的恐慌,老刑警劉巖子寓,帶你破解...
    沈念sama閱讀 216,470評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件暗挑,死亡現(xiàn)場離奇詭異,居然都是意外死亡斜友,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評論 3 392
  • 文/潘曉璐 我一進店門垃它,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鲜屏,“玉大人烹看,你說我怎么就攤上這事÷迨罚” “怎么了惯殊?”我有些...
    開封第一講書人閱讀 162,577評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長也殖。 經常有香客問我土思,道長,這世上最難降的妖魔是什么忆嗜? 我笑而不...
    開封第一講書人閱讀 58,176評論 1 292
  • 正文 為了忘掉前任己儒,我火速辦了婚禮,結果婚禮上捆毫,老公的妹妹穿的比我還像新娘闪湾。我一直安慰自己,他們只是感情好绩卤,可當我...
    茶點故事閱讀 67,189評論 6 388
  • 文/花漫 我一把揭開白布途样。 她就那樣靜靜地躺著,像睡著了一般濒憋。 火紅的嫁衣襯著肌膚如雪何暇。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,155評論 1 299
  • 那天凛驮,我揣著相機與錄音裆站,去河邊找鬼。 笑死辐烂,一個胖子當著我的面吹牛遏插,可吹牛的內容都是我干的。 我是一名探鬼主播纠修,決...
    沈念sama閱讀 40,041評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼胳嘲,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了扣草?” 一聲冷哼從身側響起了牛,我...
    開封第一講書人閱讀 38,903評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎辰妙,沒想到半個月后鹰祸,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 45,319評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡密浑,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,539評論 2 332
  • 正文 我和宋清朗相戀三年蛙婴,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片尔破。...
    茶點故事閱讀 39,703評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡街图,死狀恐怖浇衬,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情餐济,我是刑警寧澤耘擂,帶...
    沈念sama閱讀 35,417評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站絮姆,受9級特大地震影響醉冤,放射性物質發(fā)生泄漏。R本人自食惡果不足惜篙悯,卻給世界環(huán)境...
    茶點故事閱讀 41,013評論 3 325
  • 文/蒙蒙 一蚁阳、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧辕近,春花似錦韵吨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至漏峰,卻和暖如春糠悼,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背浅乔。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評論 1 269
  • 我被黑心中介騙來泰國打工倔喂, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人靖苇。 一個月前我還...
    沈念sama閱讀 47,711評論 2 368
  • 正文 我出身青樓席噩,卻偏偏與公主長得像,于是被迫代替她去往敵國和親贤壁。 傳聞我的和親對象是個殘疾皇子悼枢,可洞房花燭夜當晚...
    茶點故事閱讀 44,601評論 2 353

推薦閱讀更多精彩內容

  • 題目描述 給定一棵二叉樹,你需要計算它的直徑長度脾拆。一棵二叉樹的直徑長度是任意兩個結點路徑長度中的最大值馒索。這條路徑可...
    topshi閱讀 637評論 0 1
  • 目錄 簡書的 markdown 都不支持 [TOC] 語法……我就不貼目錄了。下面按照類別名船,列出了29道關于二叉樹...
    被稱為L的男人閱讀 3,304評論 0 8
  • 樹的定義與基本術語 ??樹型結構是一類重要的非線性數(shù)據結構绰上,其中以樹和二叉樹最為常用,是以分支關系定義的層次結構渠驼。...
    java技術分享師閱讀 1,098評論 0 1
  • 編譯環(huán)境:python v3.5.0, mac osx 10.11.4 前述內容: 線性表 隊列 堆棧 線性結構...
    擲骰子的求閱讀 2,436評論 1 7
  • 陽光正好綠蔭濃蜈块, 微風不燥夏日游。 逛山逛水汗?jié)M襟, 笑語吟吟樂無窮疯趟。
    貍歌_閱讀 846評論 7 29