[LeetCode] Longest Univalue Path

題目

原題地址
Given a binary tree, find the length of the longest path where each node in the path has the same value. This path may or may not pass through the root.

Note: The length of path between two nodes is represented by the number of edges between them.

Example 1:

Input:

          5
         / \
        4   5
       / \   \
      1   1   5

Output:

2

Example 2:

Input:

          1
         / \
        4   5
       / \   \
      4   4   5

Output:

2

Note: The given binary tree has not more than 10000 nodes. The height of the tree is not more than 1000.

思路

用遞歸解決复凳,從root節(jié)點(diǎn)開(kāi)始遍歷所有子節(jié)點(diǎn)杖刷,不走回頭路保證時(shí)間復(fù)雜度為O(n)。最長(zhǎng)路徑可能經(jīng)過(guò)root浴骂,但是也可能是在子節(jié)點(diǎn)中敬肚,所以要有一個(gè)全局變量?jī)?chǔ)存最長(zhǎng)路徑淹魄。

考慮一個(gè)節(jié)點(diǎn):

  1. 計(jì)算以它開(kāi)始向左或向右的最長(zhǎng)路徑籍铁,作為遞歸返回值傳給父節(jié)點(diǎn)
  2. 計(jì)算經(jīng)過(guò)它的最長(zhǎng)路徑(可以同時(shí)向左和向右延伸),與全局最長(zhǎng)路徑比較

python代碼

# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None

class Solution(object):
    def search(self, node):
        if node == None:
            return 0
        num1 = self.search(node.left) # 從左子節(jié)點(diǎn)開(kāi)始的最長(zhǎng)路徑
        num2 = self.search(node.right) # 從右子節(jié)點(diǎn)開(kāi)始的最長(zhǎng)路徑
        if node.left and node.left.val == node.val:
            num1 += 1 # 左子節(jié)點(diǎn)和節(jié)點(diǎn)值相同浑玛,從左子節(jié)點(diǎn)開(kāi)始的最長(zhǎng)路徑也包含了本節(jié)點(diǎn)绍申,所以+1
        else:
            num1 = 0 # 如果節(jié)點(diǎn)和左子節(jié)點(diǎn)值不同,從這個(gè)節(jié)點(diǎn)向左的路徑長(zhǎng)度就是0
        if node.right and node.right.val == node.val:
            num2 += 1
        else:
            num2 = 0 
        self.longest = max(self.longest, num1 + num2) # 經(jīng)過(guò)此節(jié)點(diǎn)的最長(zhǎng)路徑與全局最長(zhǎng)路徑比較
        return max(num1, num2) # 返回從此節(jié)點(diǎn)開(kāi)始的最長(zhǎng)路徑
        
    def longestUnivaluePath(self, root):
        """
        :type root: TreeNode
        :rtype: int
        """
        self.longest = 0 # 全局最長(zhǎng)路徑
        self.search(root)
        return self.longest
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末锄奢,一起剝皮案震驚了整個(gè)濱河市失晴,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌拘央,老刑警劉巖涂屁,帶你破解...
    沈念sama閱讀 221,198評(píng)論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異灰伟,居然都是意外死亡拆又,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門(mén)栏账,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)帖族,“玉大人,你說(shuō)我怎么就攤上這事挡爵∈悖” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 167,643評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵茶鹃,是天一觀的道長(zhǎng)涣雕。 經(jīng)常有香客問(wèn)我,道長(zhǎng)闭翩,這世上最難降的妖魔是什么挣郭? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,495評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮疗韵,結(jié)果婚禮上兑障,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好流译,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,502評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布逞怨。 她就那樣靜靜地躺著,像睡著了一般先蒋。 火紅的嫁衣襯著肌膚如雪骇钦。 梳的紋絲不亂的頭發(fā)上宛渐,一...
    開(kāi)封第一講書(shū)人閱讀 52,156評(píng)論 1 308
  • 那天竞漾,我揣著相機(jī)與錄音,去河邊找鬼窥翩。 笑死业岁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的寇蚊。 我是一名探鬼主播笔时,決...
    沈念sama閱讀 40,743評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼仗岸!你這毒婦竟也來(lái)了允耿?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,659評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤扒怖,失蹤者是張志新(化名)和其女友劉穎较锡,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體盗痒,經(jīng)...
    沈念sama閱讀 46,200評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蚂蕴,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,282評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了俯邓。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片骡楼。...
    茶點(diǎn)故事閱讀 40,424評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖稽鞭,靈堂內(nèi)的尸體忽然破棺而出鸟整,到底是詐尸還是另有隱情,我是刑警寧澤朦蕴,帶...
    沈念sama閱讀 36,107評(píng)論 5 349
  • 正文 年R本政府宣布篮条,位于F島的核電站,受9級(jí)特大地震影響梦重,放射性物質(zhì)發(fā)生泄漏兑燥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,789評(píng)論 3 333
  • 文/蒙蒙 一琴拧、第九天 我趴在偏房一處隱蔽的房頂上張望降瞳。 院中可真熱鬧,春花似錦、人聲如沸挣饥。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,264評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)扔枫。三九已至汛聚,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間短荐,已是汗流浹背倚舀。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,390評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留忍宋,地道東北人痕貌。 一個(gè)月前我還...
    沈念sama閱讀 48,798評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像糠排,于是被迫代替她去往敵國(guó)和親舵稠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,435評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • rljs by sennchi Timeline of History Part One The Cognitiv...
    sennchi閱讀 7,345評(píng)論 0 10
  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問(wèn)題, 分享了一些自己做題目的經(jīng)驗(yàn)入宦。 張土汪:刷leetcod...
    土汪閱讀 12,747評(píng)論 0 33
  • 感謝上天 張書(shū)云(秋水伊人) 他在迷人的音樂(lè)聲中靜靜地睡著了哺徊, 我不敢開(kāi)客廳的燈光, 怕他半夜醒來(lái)乾闰, 摔倒在地落追。 ...
    qiushui__lianli閱讀 155評(píng)論 3 4
  • 今天是情人節(jié),非洋人的汹忠,而是大中華傳統(tǒng)的淋硝,七夕情人節(jié)。 每年的2.14是西洋的情人節(jié)宽菜,在節(jié)前幾天乃至節(jié)日當(dāng)天谣膳,看吧...
    煩人的昵稱(chēng)閱讀 223評(píng)論 0 1
  • 王柏林 公司: 都江堰佳音英語(yǔ) 【日精進(jìn)打卡第97天】 【知~學(xué)習(xí)】 《六項(xiàng)精進(jìn)》 《大學(xué)》 【名句】 認(rèn)為不行的...
    berlin_eda3閱讀 146評(píng)論 0 0