力扣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;
    }
}
相关推荐
全靠bug跑18 小时前
Spring Cache 实战:核心注解详解与缓存过期时间配置
java·redis·springcache
Swift社区18 小时前
LeetCode 465 最优账单平衡
算法·leetcode·职场和发展
聆风吟º18 小时前
【数据结构手札】空间复杂度详解:概念 | 习题
java·数据结构·算法
weixin_4450547218 小时前
力扣热题51
c++·python·算法·leetcode
计算机程序设计小李同学18 小时前
基于SpringBoot的个性化穿搭推荐及交流平台
java·spring boot·后端
是一个Bug18 小时前
50道核心JVM面试题
java·开发语言·面试
地平线开发者18 小时前
linux 常见稳定性问题分析方法
算法·自动驾驶
朱朱没烦恼yeye18 小时前
java基础学习
java·python·学习
s砚山s18 小时前
代码随想录刷题——二叉树篇(九)
算法
地平线开发者19 小时前
大模型常见量化方法简介
算法·自动驾驶