-
题目
java给你一个整数数组 nums ,其中元素已经按 升序 排列, 请你将其转换为一棵平衡二叉搜索树。 -
示例
java示例 1: 输入:nums = [-10,-3,0,5,9] 输出:[0,-3,9,-10,null,5] 解释:[0,-10,5,null,-3,null,9] 也将被视为正确答案: 示例 2: 输入:nums = [1,3] 输出:[3,1] 解释:[1,null,3] 和 [3,1] 都是高度平衡二叉搜索树。 -
解题思路
- 利用二分查找的思想,每找到一个元素,就将其构造成一个节点。并且因为数组本身已经排序,直接构造即可。
-
代码(Java)
javaclass Solution { public TreeNode sortedArrayToBST(int[] nums) { if (nums == null) { return null; } if (nums.length == 1) { return new TreeNode(nums[0]); } return sortedArrayToBST(nums, 0, nums.length - 1, (nums.length - 1) / 2); } public TreeNode sortedArrayToBST(int[] nums, int left, int right, int mid) { if (left > right) { return null; } TreeNode root = new TreeNode(nums[mid]); root.left = sortedArrayToBST(nums, left, mid - 1, (left + mid - 1) / 2); root.right = sortedArrayToBST(nums, mid + 1, right, (mid + 1 + right) / 2); return root; } }
LeetCode108 将有序数组转换为二叉搜索树
biglxl2024-03-19 20:46
相关推荐
努力长头发的程序猿14 小时前
Unity2D当中的A*寻路算法Raink老师15 小时前
用100道题拿下你的算法面试(矩阵篇-2):求转置矩阵算法鑫探21 小时前
闰年判断:C语言实战解析WBluuue21 小时前
数据结构与算法:康托展开、约瑟夫环、完美洗牌木子墨51621 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌EQUINOX11 天前
2026年码蹄杯 本科院校赛道&青少年挑战赛道提高组初赛(省赛)第一场,个人题解萝卜小白1 天前
算法实习Day04-MinerU2.5-proLiangwei Lin1 天前
洛谷 P3133 [USACO16JAN] Radio Contact Gweixin_513449961 天前
PCA、SVD 、 ICP 、kd-tree算法的简单整理总结