98. Validate Binary Search Tree
給定root
二叉樹的 ,確定它是否是有效的二叉搜索樹 (BST)。
一個有效的 BST定義如下:
- 左邊子樹節點的僅包含鍵小於節點鍵的節點。
- 節點的右子樹僅包含鍵大於節點鍵的節點。
- 左右子樹也必須是二叉搜索樹。
recursively
data:image/s3,"s3://crabby-images/f0882/f0882e97a41d22bba4d6df0ed8ca94aad43e3bbd" alt=""
data:image/s3,"s3://crabby-images/022d3/022d39d4f1ec16d634d0991497031940d31ef5db" alt=""
Inorder- recursively的解法
data:image/s3,"s3://crabby-images/77d9d/77d9d2660080a52b1eaef47265aa5465c477d943" alt=""
938. Range Sum of BST
Preorder-Iteratively 的解法
data:image/s3,"s3://crabby-images/131f1/131f1aa51813cc3de518e13689d896a97f41af44" alt=""
Postorder-recursively的解法
data:image/s3,"s3://crabby-images/bc79b/bc79bba4e93eb0811d02e8abd31d0f1eaeca4734" alt=""
data:image/s3,"s3://crabby-images/567aa/567aa0d6cf3aca016df5f8978eb7d565dd7f3f9d" alt=""
95. Unique Binary Search Trees II
可能的組合方法
當n=3時可以重複去用剛剛n=1和n=2的組合
data:image/s3,"s3://crabby-images/76ec5/76ec51cd26a54e5fa8041ce4c9afe8dd7f50b31f" alt=""
recursively的解法
data:image/s3,"s3://crabby-images/acc1a/acc1ac9b6bd7ce4f33b34b99b2220565742ea031" alt=""
data:image/s3,"s3://crabby-images/51d97/51d9746fb50c31f0d9fb130897ff7382355352eb" alt=""
144. Binary Tree Preorder Traversal
Morris的解法
- Morris-Preorder-Iteratively 的解法
data:image/s3,"s3://crabby-images/58a3c/58a3cd28980498b577b98185d5f9cf8024701e23" alt=""
Preorder-Iteratively 的解法
data:image/s3,"s3://crabby-images/57d03/57d03a58e57cfa96392d5b7cf7c1fffa7cf5ac06" alt=""
94. Binary Tree Inorder Traversal
Inorder-Iteratively 的解法
這一題跟就是144題的Inorder做法,只需要把output.append(root.val)換到else條件中就好
data:image/s3,"s3://crabby-images/f3688/f3688c91ba27c9ec729416a392c26ef94b770a29" alt=""
data:image/s3,"s3://crabby-images/607a9/607a9197e6591947adc0abf6ac3feb71bdfa75aa" alt=""
145. Binary Tree Postorder Traversal
Postorder-Iteratively 的解法
以下和上面Preorder-Iteratively 的解法只差在先遍歷右在遍歷左,之後再用reversed()去返回列表的逆序迭代器
data:image/s3,"s3://crabby-images/75e19/75e19166ec49bf3630b321a891f96be8d31b7b35" alt=""