一次過 Lintcode 175 翻轉二叉樹

2021-08-21 10:36:21 字數 865 閱讀 2298

翻轉一棵二叉樹

1         1

/ \ / \

2 3 => 3 2

/ \

4 4

遞迴固然可行,能否寫個非遞迴的?

遞迴。先將左孩子為根的子樹翻轉,再將右孩子為根的子樹翻轉,最後將該節點的左右子樹翻轉即可。

/**

* definition of treenode:

* public class treenode

* }*/public class solution

}

非遞迴版本1,類似於dfs,自頂向下翻轉。

/**

* definition of treenode:

* public class treenode

* }*/public class solution

}}

類似於二叉樹遍歷的非遞迴版本,用棧來模擬系統棧。

/**

* definition of treenode:

* public class treenode

* }*/public class solution

root = stack.pop();

treenode temp = root.left;

root.left = root.right;

root.right = temp;

root = root.left;//本應該遍歷到右子樹的,但由於左右子樹翻轉後,原來的右子樹成了左子樹。}}

}

一次過 Lintcode 488 快樂數

寫乙個演算法來判斷乙個數是不是 快樂數 乙個數是不是快樂是這麼定義的 對於乙個正整數,每一次將該數替換為他每個位置上的數字的平方和,然後重複這個過程直到這個數變為1,或是無限迴圈但始終變不到1。如果可以變為1,那麼這個數就是快樂數。19 就是乙個快樂數。1 2 9 2 82 8 2 2 2 68 6...

一次過 Lintcode 496 玩具工廠

工廠模式是一種常見的設計模式。請實現乙個玩具工廠toyfactory用來產生不同的玩具類。可以假設只有貓和狗兩種玩具。toyfactory tf toyfactory toy toy tf.gettoy dog toy.talk wow toy tf.gettoy cat toy.talk meow...

一次過 Lintcode 956 資料分割

給出乙個字串str,你需要按順序提取出該字串的符號和單詞。樣例 1 輸入 str hi i am bye 輸出 hi i am bye 解釋 將符號和單詞分割。樣例 2 輸入 str ok yes 輸出 ok yes 解釋 將符號和單詞分割。樣例 3 輸入 str s 輸出 s 解釋 將符號和單詞分...