劍指offer 27 二叉樹的映象

2021-10-04 20:00:14 字數 1169 閱讀 6124

面試題27. 二叉樹的映象

難度簡單15

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

例如輸入:

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]

時間複雜度:o(n) 建立二叉樹的所有結點遍歷一遍

空間複雜度:o(n) 最壞情況下 二叉樹退化成煉表,需要n個儲存空間。

//1.暫存左節點

//2.遞迴遍歷右節點。

// a.右節點不為空繼續下一層

// b.右節點為空 直接作為根節點的左節點。

//3.遞迴遍歷左節點

// a.左節點不為空繼續下一層

// b.右節點為空 直接作為根節點的右節點。

// 如此反覆就可以修改。

public treenode mirrortree

(treenode root)

時間複雜度:o(n) 遍歷一下結點的個數

空間複雜度:o(n) 儲存所有結點的次數

//1.根節點儲存到stack中

//2.當stack 不為null 將根節點pop出來。

// a.如果root.left不為null stack.push -> root.left

// b.如果root.right不為null stack.push -> root.right

//3.暫存left節點

// a.交換左右節點 依次迴圈遍歷。

//返回根節點

public treenode mirrortree

(treenode root)

stack

stack =

newstack()

; stack.

push

(root)

;while

(!stack.

isempty()

)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...