二叉樹

求解二叉樹問題從遞歸著手

Problem 1

計(jì)算二叉樹的形狀
卡特蘭樹的經(jīng)典應(yīng)用
即給定n個(gè)節(jié)點(diǎn)允蜈,計(jì)算有多少個(gè)不同形狀的二叉樹蒿柳,考慮當(dāng)只有一個(gè)節(jié)點(diǎn)或者沒有節(jié)點(diǎn)時(shí)樹只有1個(gè)形狀,當(dāng)有多個(gè)節(jié)點(diǎn)時(shí)妓蛮,給根節(jié)點(diǎn)分配一個(gè)圾叼,左右兩邊各有不同的分法,以此類推构挤,采用遞歸求解惕鼓,符合卡特蘭數(shù)的表達(dá),代碼如下:

def count(n):
    # root : 1
    # left : k [0,n-1]
    # right : n - 1 - k
 
    if n == 0:
        return 1
    sum = 0
    for k in range(n):
        sum += count(k) * count(n-1-k)
    return sum

Problem 2

計(jì)算二叉樹的最近祖先
Leetcode 236
Given a binary tree, find the lowest common ancestor (LCA) of two given nodes in the tree.

According to the definition of LCA on Wikipedia: “The lowest common ancestor is defined between two nodes p and q as the lowest node in T that has both p and q as descendants (where we allow a node to be a descendant of itself).”

image.png

思路:
解二叉樹的問題一般都往遞歸方向靠攏矾飞,首先考慮特殊情況若p和q其中之一是根節(jié)點(diǎn)呀邢,或者根節(jié)點(diǎn)不存在的情況,直接返回根節(jié)點(diǎn)微谓;
然后從左右子樹中找最近祖先,根據(jù)左右子樹中查找的情況返回結(jié)果豺型,如下代碼所示:

class Solution(object):
    def lowestCommonAncestor(self, root, p, q):
        """
        :type root: TreeNode
        :type p: TreeNode
        :type q: TreeNode
        :rtype: TreeNode
        """
        if p==root or q==root or root==None:
            return root
        left=self.lowestCommonAncestor(root.left,p,q)
        right=self.lowestCommonAncestor(root.right,p,q)
        if left==None and right!=None:
            return right
        if left!=None and right==None:
            return left
        if left==None and right==None:
            return None
        return root

Problem 3驗(yàn)證二叉樹是否為二叉查找樹

Given the root of a binary tree, determine if it is a valid binary search tree (BST).

A valid BST is defined as follows:

The left subtree of a node contains only nodes with keys less than the node's key.
The right subtree of a node contains only nodes with keys greater than the node's key.
Both the left and right subtrees must also be binary search trees.


image.png

思路:
鄙人剛開始的想法是遞歸判斷節(jié)點(diǎn)的左子樹的值比根節(jié)點(diǎn)小姻氨,右子樹的值比根節(jié)點(diǎn)大,如此可以保證局部的子樹是二叉查找樹前联,但并不能保證全局的結(jié)果娶眷,于是乎,轉(zhuǎn)用其他方法烁落,二叉查找樹的中序遍歷結(jié)果必然是有序的豌注,如此得到了AC,代碼如下:

 ret=[]
        stack=[]
        while stack or root:
            if root:
                stack.append(root)
                root = root.left
            else:
                temNode = stack.pop()
                ret.append(temNode.val)
                root = temNode.right
        return all([ret[i] < ret[i+1] for i in range(len(ret)-1)])

補(bǔ)充二叉樹的前序轧铁、中序齿风、后序遍歷是基礎(chǔ)中的基礎(chǔ),需要熟練掌握救斑。

Probelm4二叉樹的子樹和子結(jié)構(gòu)判斷

樹的子結(jié)構(gòu)判斷

def isSubStructure(self, A: TreeNode, B: TreeNode) -> bool:
            if A==None or B==None:
                return False
            elif A.val==B.val:
                return  A.val==B.val or self.isSubStructure(A.left,B.left) or self.isSubStructure(A.right,B.right)
            else:
                return self.isSubStructure(A.left,B) or self.isSubStructure(A.right,B)

樹的子樹判斷
如果兩個(gè)數(shù)的根節(jié)點(diǎn)相同,判斷兩個(gè)樹是否相等巾陕,否則判斷左右子樹是否是子樹的關(guān)系纪他。

class Solution:
    def isSubtree(self, root: TreeNode, subRoot: TreeNode) -> bool:
        def isEqual(S,T): 
            if not S and not T:  
                return True  
            if S and T:  
                if S.val!=T.val:  
                    return False  
                return isEqual(S.left,T.left) and isEqual(S.right,T.right)  
            else:  
                return False

        if not root:
                return False
        return isEqual(root,subRoot) or self.isSubtree(root.left,subRoot) or self.isSubtree(root.right,subRoot) 
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末茶袒,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子薪寓,更是在濱河造成了極大的恐慌,老刑警劉巖锥腻,帶你破解...
    沈念sama閱讀 219,539評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異京革,居然都是意外死亡幸斥,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門廊勃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來经窖,“玉大人,你說我怎么就攤上這事√ピ矗” “怎么了?”我有些...
    開封第一講書人閱讀 165,871評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵宪卿,是天一觀的道長(zhǎng)万栅。 經(jīng)常有香客問我,道長(zhǎng)休溶,這世上最難降的妖魔是什么扰她? 我笑而不...
    開封第一講書人閱讀 58,963評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮孽尽,結(jié)果婚禮上忧勿,老公的妹妹穿的比我還像新娘瞻讽。我一直安慰自己,他們只是感情好速勇,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評(píng)論 6 393
  • 文/花漫 我一把揭開白布婆瓜。 她就那樣靜靜地躺著,像睡著了一般个初。 火紅的嫁衣襯著肌膚如雪猴蹂。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,763評(píng)論 1 307
  • 那天珍逸,我揣著相機(jī)與錄音聋溜,去河邊找鬼。 笑死撮躁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的杨帽。 我是一名探鬼主播嗤军,決...
    沈念sama閱讀 40,468評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼老客!你這毒婦竟也來了震叮?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,357評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤朴则,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后乌妒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,850評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡古掏,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評(píng)論 3 338
  • 正文 我和宋清朗相戀三年槽唾,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片庞萍。...
    茶點(diǎn)故事閱讀 40,144評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡忘闻,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出私恬,到底是詐尸還是另有隱情炼吴,我是刑警寧澤,帶...
    沈念sama閱讀 35,823評(píng)論 5 346
  • 正文 年R本政府宣布荣德,位于F島的核電站提针,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏辐脖。R本人自食惡果不足惜皆愉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望久锥。 院中可真熱鬧异剥,春花似錦、人聲如沸冤寿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至丰歌,卻和暖如春屉凯,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背神得。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工哩簿, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人节榜。 一個(gè)月前我還...
    沈念sama閱讀 48,415評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像稼稿,于是被迫代替她去往敵國(guó)和親讳窟。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評(píng)論 2 355

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