Binary Tree(二叉樹)是一種樹形結構,每個節點最多只有兩個子節點(左節點和右節點)的linkedlist。Binary Tree中每個節點都包含一個值和一個指向左節點和右節點的指針。
Binary Tree的算法是先序遍歷,從root node開始,先輸出root node,然後遍歷左子樹,最後遍歷右子樹。具體步驟如下:
當變數有指到node的情況下
- 盡量往左走
- 走到的先拜訪 (你要做的事)
當變數沒有指到node
- 判斷是不是走不下去,若走不下去往上找可以的parent.right回到root node
data:image/s3,"s3://crabby-images/c3918/c3918d4dd1b5527c31cdaf8fcd5b8968b554d3b4" alt=""
以下code可以帶入各種Binary Tree的題目,其中root表示Binary Tree的根節點,stack是一個堆疊,用來暫存未處理的節點。程式碼首先將根節點入堆疊,然後遍歷其左子樹直到左子樹的末端,期間遇到的所有節點都加入堆疊。當左子樹處理完成後,程式碼從堆疊中取出節點,遍歷其右子樹。這樣依次處理所有節點,就完成了二叉樹的前序遍歷。
root = Tree()
stack = []
while stack or root:
if root:
print(root.val) # visit
stack.append(root)
root = root.left
else:
root = stack.pop()
root = root.right
以下是用preorder的方法去解leetcode的Binary Tree
112. Path Sum
data:image/s3,"s3://crabby-images/8eedc/8eedcc277992fefba4a1c8c46708c6cb3c8b0a03" alt=""
104. Maximum Depth of Binary Tree
data:image/s3,"s3://crabby-images/83205/83205a193bf286e1ef4d3aac72c0cea434f9ea06" alt=""
257. Binary Tree Paths
data:image/s3,"s3://crabby-images/2f4a3/2f4a35f69be45c3491772eece9eb82346f8d4699" alt=""
144. Binary Tree Preorder Traversal
data:image/s3,"s3://crabby-images/c73bc/c73bc91e418ad9bc21d7e559f64d523c7bf36074" alt=""
100. Same Tree
1.寫一個函式,來檢查兩個Binary Tree是否相同。可以使用前序遍歷來比較兩個Binary Tree
data:image/s3,"s3://crabby-images/a47bc/a47bca84ced20c743e910080cabe12284b1d462d" alt=""
700. Search in a Binary Search Tree
data:image/s3,"s3://crabby-images/5cf2f/5cf2fcadaa673bee455deb73e5c955b1f57a5c28" alt=""