力扣HOT100 - 108. 将有序数组转换为二叉搜索树

解题思路:

二叉搜索树一般使用中序遍历

java 复制代码
class Solution {
    public TreeNode sortedArrayToBST(int[] nums) {
        return helper(nums,0,nums.length-1);
    }
    public TreeNode helper(int[] nums,int left,int right){
        if(left>right) return null;

        //确定根节点
        //总是选择中间位置左边的数字作为根节点
        //也可以用 int mid = (left + right + 1) / 2; 总是选择中间位置右边的数字作为根节点
        int mid=(left+right)/2;
        TreeNode root=new TreeNode(nums[mid]);

        root.left=helper(nums,left,mid-1);
        root.right=helper(nums,mid+1,right);
        return root;
    }
}
相关推荐
怕浪猫1 小时前
Electron 系列文章封面图
算法·架构·前端框架
plainGeekDev1 小时前
null 判断 → Kotlin 可空类型
android·java·kotlin
糖拌西瓜皮1 小时前
Java开发者视角:深入理解Node.js异步编程模型
java·后端·node.js
plainGeekDev1 小时前
getter/setter → Kotlin 属性
android·java·kotlin
一线大码1 小时前
Smart-Doc 的简单使用
java·后端·restful
MacroZheng3 小时前
Claude Code官方桌面端正式发布,夯爆了!
java·人工智能·后端
虚无境3 小时前
如何编写一个SpringBoot项目告警推送的Starter
java·prometheus·webhook
徐小夕3 小时前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
NE_STOP18 小时前
Vide Coding--AI编程工具的选择
java