映象二叉樹 劍指 Offer 27 二叉樹的映象

2021-10-08 16:16:04 字數 1200 閱讀 7117

請完成乙個函式,輸入乙個二叉樹,該函式輸出它的映象。

例如輸入:

4/   \

2     7

/ \   / \

1   3 6   9

映象輸出:

4/   \

7     2

/ \   / \

9   6 3   1

示例 1:

輸入:root = [4,2,7,1,3,6,9]

輸出:[4,7,2,9,6,3,1]

什麼是映象二叉樹,就是交換每乙個節點的左右子樹,重構的二叉樹就稱之為原二叉樹的映象。遇到樹的問題,兩種解法:1、遞迴求解;2、輔助棧法

輔助棧

# definition for a binary tree node.

# class treenode:

# def __init__(self, x):

# self.val = x

# self.left = none

# self.right = none

class solution:

def mirrortree(self, root: treenode) -> treenode:

#輔助棧法

if not root:

return

stack = [root]

while stack:

node = stack.pop()

if node.left:

if node.right:

node.left,node.right = node.right,node.left

return root

#遞迴法

#交換左右兩個子樹

root.left,root.right = root.right,root.left

print(root.left,root.right)

#遞迴的交換兩個子樹

self.mirrortree(root.left)

self.mirrortree(root.right)

return root

總結:不管構建樹還是遍歷樹,遞迴都是最優先的。

這題和反轉二叉樹一毛一樣。

劍指offer 27 二叉樹的映象

宣告 本系列部落格是對何海濤 劍指offer 的關鍵點總結。1.樹的映象 定義 樹的根結點相同,但是左右兩個子節點交換了位置 2.解題思路 1 前序遍歷樹的每乙個結點 2 如果遍歷到的節點有子節點,則交換其左右兩個子節點 3 分別以左子節點和右子節點作為新的根結點,遞迴呼叫該函式 4 當遍歷到的結點...

劍指Offer 27 二叉樹的映象

請完成乙個函式,輸入一棵二叉樹,該函式輸出它的映象。例 8 8 6 10 10 6 5 7 9 11 11 9 7 5交換左右子樹,遍歷至葉節點終止即可。時間複雜度 o n 空間複雜度 o 1 def mirror of binary tree root param root root return...

劍指offer 27 二叉樹的映象

思路 先前序遍歷這顆樹的每個節點,如果遍歷到的節點有子節點,就交換它的兩個子節點。當交換完所有非葉節點的左右節點之後就得到了樹的映象。class treenode def init self,x self.val x self.left none self.right none class solu...