力扣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;
    }
}
相关推荐
IT利刃出鞘14 小时前
Java多线程--三种写法(Thread、Runnable、Callable)
java·多线程
c2385614 小时前
c/c++中的二叉树进阶
c语言·c++·算法
两年半的个人练习生^_^14 小时前
JMM 进阶:彻底理解 volatile 实现原理
java·开发语言
吴可可12314 小时前
Win7下C#开发AutoCAD首选版本
算法
Yeats_Liao14 小时前
Java网络编程(五):Selector选择器与高并发实现
java·后端·架构
AC赳赳老秦15 小时前
OpenClaw任务复盘自动化:统计每日完成工作、遗留问题,优化工作节奏
java·大数据·linux·运维·服务器·数据库·openclaw
兰令水15 小时前
leecodecode【层序遍历】【2026.6.3打卡-java版本】
java·开发语言
Halo_tjn15 小时前
反射与设计模式2
java·开发语言·算法
YDS82915 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— 动态决策策略的接口对接
java·spring boot·ai·agent·spring ai·deepseek
zfoo-framework15 小时前
跨服架构设计模式(同构进程+选主转发)
java