Giả sử chúng ta có một mảng được sắp xếp A. Chúng ta phải tạo một tìm kiếm nhị phân cân bằng độ cao. Trong bài toán này, cây nhị phân cân bằng độ cao thực sự là một cây nhị phân trong đó độ sâu của hai cây con của mọi nút không bao giờ khác nhau quá 1. Giả sử mảng giống như [-10, -3, 0, 5, 9 ]. Vì vậy, một đầu ra có thể có sẽ giống như:[0, -3, 9, -10, null, 5]
Để giải quyết vấn đề này, chúng tôi sẽ làm theo các bước sau.
- Nếu A trống, thì trả về Null
- tìm phần tử giữa và đặt phần tử gốc
- Chia mảng thành hai mảng con, phần bên trái của phần tử giữa và phần bên phải của phần tử giữa
- thực hiện đệ quy cùng một tác vụ cho mảng con bên trái và mảng con bên phải.
Hãy cùng chúng tôi xem cách triển khai sau đây để hiểu rõ hơn -
Ví dụ
class TreeNode: def __init__(self, data, left = None, right = None): self.data = data self.left = left self.right = right def insert(temp,data): que = [] que.append(temp) while (len(que)): temp = que[0] que.pop(0) if (not temp.left): if data is not None: temp.left = TreeNode(data) else: temp.left = TreeNode(0) break else: que.append(temp.left) if (not temp.right): if data is not None: temp.right = TreeNode(data) else: temp.right = TreeNode(0) break else: que.append(temp.right) def make_tree(elements): Tree = TreeNode(elements[0]) for element in elements[1:]: insert(Tree, element) return Tree def height(root): if root is None: return 0 else : # Compute the height of left and right subtree l_height = height(root.left) r_height = height(root.right) #Find the greater one, and return it if l_height > r_height : return l_height+1 else: return r_height+1 def print_given_level(root, level): if root is None: return if level == 1: print(root.data,end = ',') elif level > 1 : print_given_level(root.left , level-1) print_given_level(root.right , level-1) def level_order(root): print('[', end = '') h = height(root) for i in range(1, h+1): print_given_level(root, i) print(']') class Solution(object): def sortedArrayToBST(self, nums): """ :type nums: List[int] :rtype: TreeNode """ if not nums: return None mid = nums[len(nums)//2] root = TreeNode(mid) root.left = self.sortedArrayToBST(nums[:len(nums)//2]) root.right = self.sortedArrayToBST(nums[len(nums)//2 +1 :]) return root nums = [-10,-3,0,5,9] ob1 = Solution() bst = ob1.sortedArrayToBST(nums) level_order(bst)
Đầu vào
nums = [-10,-3,0,5,9]
Đầu ra
[0,-3,9,-10,5,]