-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathConvertSortedListToBinarySearchTree.js
84 lines (77 loc) · 2.11 KB
/
ConvertSortedListToBinarySearchTree.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
// Source : https://leetcode.com/problems/convert-sorted-list-to-binary-search-tree
// Author : Dean Shi
// Date : 2021-12-14
/***************************************************************************************
* Given the head of 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 1:
*
* Input: head = [-10,-3,0,5,9]
* Output: [0,-3,9,-10,null,5]
* Explanation: One possible answer is [0,-3,9,-10,null,5], which represents the shown
* height balanced BST.
*
* Example 2:
*
* Input: head = []
* Output: []
*
* Example 3:
*
* Input: head = [0]
* Output: [0]
*
* Example 4:
*
* Input: head = [1,3]
* Output: [3,1]
*
* Constraints:
*
* The number of nodes in head is in the range [0, 2 * 104].
* -105 <= Node.val <= 105
*
*
***************************************************************************************/
/**
* Definition for singly-linked list.
* function ListNode(val, next) {
* this.val = (val===undefined ? 0 : val)
* this.next = (next===undefined ? null : next)
* }
*/
/**
* Definition for a binary tree node.
* function TreeNode(val, left, right) {
* this.val = (val===undefined ? 0 : val)
* this.left = (left===undefined ? null : left)
* this.right = (right===undefined ? null : right)
* }
*/
/**
* @param {ListNode} head
* @return {TreeNode}
*/
var sortedListToBST = function(head) {
return getMidNode(head)
};
function getMidNode(head, tail = null) {
if (head === tail) return null
let [fastPt, slowPt] = [head, head]
while (fastPt !== tail) {
fastPt = fastPt.next
if (fastPt !== tail) {
fastPt = fastPt.next
slowPt = slowPt.next
}
}
return new TreeNode(
slowPt.val,
getMidNode(head, slowPt), // left: the first node to the middle node
getMidNode(slowPt.next, fastPt) // right: the next of middle node to the end
)
}