题目
Given a singly linked list where elements are sorted in ascending order, convert it to a height balanced BST.
For this problem, a height-balanced binary tree is defined as a binary tree in which the depth of the two subtrees of every node never differ by more than 1.
Example:
Given the sorted linked list: [-10,-3,0,5,9],
One possible answer is: [0,-3,9,-10,null,5], which represents the following height balanced BST:
0
/ \
-3 9
/ /
-10 5
解题思路
这道题跟LeetCode: 108. Convert Sorted Array to Binary Search Tree一样,但从array变成list。一个最直观的做法就是先把list转换为array,再调用108的函数就可以啦。
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
def sortedListToBST(self, head: ListNode) -> TreeNode:
nums= []
while head is not None:
nums.append(head.val)
head = head.next
if len(nums)==0:
return None
l=int(len(nums)/2)
root = TreeNode(nums[l])
root.left = self.sortedArrayToBST(nums[:l])
root.right = self.sortedArrayToBST(nums[l+1:])
return root
def sortedArrayToBST(self, nums: List[int]) -> TreeNode:
if len(nums)==0:
return None
l=int(len(nums)/2)
root = TreeNode(nums[l])
root.left = self.sortedArrayToBST(nums[:l])
root.right = self.sortedArrayToBST(nums[l+1:])
return root
这个做法有点绕,我去看看大佬的做法。
用了快慢指针确定中位数,然后递归调用自己。
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, x):
# self.val = x
# self.left = None
# self.right = None
class Solution:
def sortedListToBST(self, head: ListNode) -> TreeNode:
if head is None:
return
if head.next is None:
return TreeNode(head.val)
slow = head
fast = head.next.next
while fast and fast.next:
fast = fast.next.next
slow = slow.next
# tmp points to root
tmp = slow.next
# cut down the left child
slow.next = None
root = TreeNode(tmp.val)
root.left = self.sortedListToBST(head)
root.right = self.sortedListToBST(tmp.next)
return root