摘要:二分法找到数组的中位数,置为树的,递归找到前半段和后半段的中位数,分别置为左右子树。
Problem
Given a sorted (increasing order) array, Convert it to create a binary tree with minimal height.
ExampleGiven [1,2,3,4,5,6,7], return
</>复制代码
4
/
2 6
/ /
1 3 5 7
Note
二分法找到数组的中位数,置为树的root,递归找到前半段和后半段的中位数,分别置为左右子树。直到start = mid或end = mid为止。
Solution Recursive</>复制代码
public class Solution {
public TreeNode sortedArrayToBST(int[] A) {
return helper(0, A.length - 1, A);
}
public TreeNode helper(int start, int end, int[]A) {
if (start > end) return null;
int mid = start + (end - start) / 2;
TreeNode root = new TreeNode(A[mid]);
root.left = helper(start, mid - 1, A);
root.right = helper(mid + 1, end, A);
return root;
}
}
Iterative
</>复制代码
class Solution {
public TreeNode sortedArrayToBST(int[] nums) {
if (nums == null || nums.length == 0) return null;
TreeNode head = new TreeNode(0);
Deque nodeStack = new LinkedList<>();
Deque leftIndexStack = new LinkedList<>();
Deque rightIndexStack = new LinkedList<>();
nodeStack.push(head);
leftIndexStack.push(0);
rightIndexStack.push(nums.length-1);
while (!nodeStack.isEmpty()) {
TreeNode curNode = nodeStack.pop();
int left = leftIndexStack.pop();
int right = rightIndexStack.pop();
int mid = left+(right-left)/2;
curNode.val = nums[mid];
if (left < mid) {
curNode.left = new TreeNode(0);
nodeStack.push(curNode.left);
leftIndexStack.push(left);
rightIndexStack.push(mid-1);
}
if (mid < right) {
curNode.right = new TreeNode(0);
nodeStack.push(curNode.right);
leftIndexStack.push(mid+1);
rightIndexStack.push(right);
}
}
return head;
}
}
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/65563.html
摘要:解题思路平衡二叉树,其实就是数组中间的数作为根,利用递归实现左子树和右子树的构造。 Convert Sorted Array to Binary Search TreeGiven an array where elements are sorted in ascending order, convert it to a height balanced BST. 1.解题思路平衡二叉树,...
摘要:我们可以用和两个值来限定子树在链表中的位置,通过递归的方式,深入找到最左边,然后开始顺序遍历链表链表当前节点作为全局变量,这样无论递归在哪我们都能拿到,同时建树。代码先递归的计算左子树创造根节点最后递归的计算右子树 Convert Sorted List to Binary Search Tree Given a singly linked list where elements ar...
摘要:自己没事刷的一些的题目,若有更好的解法,希望能够一起探讨项目地址 自己没事刷的一些LeetCode的题目,若有更好的解法,希望能够一起探讨 Number Problem Solution Difficulty 204 Count Primes JavaScript Easy 202 Happy Number JavaScript Easy 190 Reverse Bi...
摘要:在线网站地址我的微信公众号完整题目列表从年月日起,每天更新一题,顺序从易到难,目前已更新个题。这是项目地址欢迎一起交流学习。 这篇文章记录我练习的 LeetCode 题目,语言 JavaScript。 在线网站:https://cattle.w3fun.com GitHub 地址:https://github.com/swpuLeo/ca...我的微信公众号: showImg(htt...
摘要:月下半旬攻略道题,目前已攻略题。目前简单难度攻略已经到题,所以后面会调整自己,在刷算法与数据结构的同时,攻略中等难度的题目。 Create by jsliang on 2019-07-30 16:15:37 Recently revised in 2019-07-30 17:04:20 7 月下半旬攻略 45 道题,目前已攻略 100 题。 一 目录 不折腾的前端,和咸鱼有什么区别...
阅读 3536·2019-08-30 13:15
阅读 1487·2019-08-29 18:34
阅读 914·2019-08-29 15:18
阅读 3546·2019-08-29 11:21
阅读 3327·2019-08-29 10:55
阅读 3787·2019-08-26 10:36
阅读 1951·2019-08-23 18:37
阅读 1923·2019-08-23 16:57