劍指 Offer 對稱的二叉樹

2021-10-07 18:29:34 字數 1204 閱讀 7397

復仇bytedance之路

請實現乙個函式,用來判斷一棵二叉樹是不是對稱的。如果一棵二叉樹和它的映象一樣,那麼它是對稱的。

例如,二叉樹 [1,2,2,3,4,4,3] 是對稱的。

1

/ \ 2

2/ \ / \34

43

但是下面這個 [1,2,2,null,3,null,3] 則不是映象對稱的:

1

/ \ 2

2 \ \

33

示例 1:

輸入:root =[1

,2,2

,3,4

,4,3

]輸出:true

示例 2:

輸入:root =[1

,2,2

,null,

3,null,3]

輸出:false

限制:

0

<= 節點個數 <=

1000

涉及到二叉樹的題目大概率都會使用到遞迴

/**

* definition for a binary tree node.

* public class treenode

* }*/class

solution

return

mysymmetric

(root.left,root.right);}

public

boolean

mysymmetric

(treenode l,treenode r)

//退出判斷,左右子樹有乙個不為null

if(l==null||r==null)

//退出判斷,當前值是否相等

if(l.val!=r.val)

//遞迴判斷:左的左子樹和右的右子樹&&左的右子樹和右的左子樹。這樣才是映象

return

mysymmetric

(l.left,r.right)

&&mysymmetric

(l.right,r.left);}

}

寫一下不成熟的遞迴感悟:

劍指Offer 二叉樹 對稱的二叉樹

含有兩道題,都從樹的遞迴入手 請完成乙個函式,輸入乙個二叉樹,該函式輸出它的映象。解題思路 映象翻 只需要遍歷二叉樹,每次訪問乙個結點時,交換其左右子樹。實現 definition for a binary tree node.class treenode def init self,x self....

劍指offer 對稱的二叉樹

請實現乙個函式,用來判斷一顆二叉樹是不是對稱的。注意,如果乙個二叉樹同此二叉樹的映象是同樣的,定義其為對稱的。思路 複製一顆二叉樹,在該二叉樹的基礎上求得二叉樹的映象,同時遍歷兩顆二叉樹,判斷每乙個節點是否相同。public class solution private treenode copy ...

劍指offer 對稱的二叉樹

請實現乙個函式,用來判斷一顆二叉樹是不是對稱的。注意,如果乙個二叉樹同此二叉樹的映象是同樣的,定義其為對稱的。遞迴 coding utf 8 class treenode def init self,x self.val x self.left none self.right none class ...