-
题目
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
相关推荐
chao18984428 分钟前
基于 SPEA2 的多目标优化算法 MATLAB 实现沪漂阿龙29 分钟前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解little~钰1 小时前
倍增算法和ST表知识领航员2 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景薛定e的猫咪2 小时前
因果推理研究方向综述笔记如何原谅奋力过但无声3 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)平行侠3 小时前
037插入排序 - 整理扑克牌的算法ECT-OS-JiuHuaShan3 小时前
彻底定理化:从量子纠缠到量子代谢爱喝雪碧的可乐4 小时前
2026 腾讯广告算法大赛优秀方案启示:行为条件化多模态自回归生成推荐摘要