力扣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;
    }
}
相关推荐
KerwinChou_CN几秒前
LangGraph 快速入门
服务器·网络·算法
不光头强几秒前
Java中的异常
java·开发语言
毕设源码-赖学姐1 分钟前
【开题答辩全过程】以 高校资源共享平台的设计与实现 为例,包含答辩的问题和答案
java
shamalee4 分钟前
MS SQL Server partition by 函数实战二 编排考场人员
java·服务器·开发语言
aisifang004 分钟前
MS SQL Server partition by 函数实战三 成绩排名
java
C++chaofan14 分钟前
JUC 并发编程:对可见性、有序性与 volatile的理解
java·开发语言·spring·java-ee·juc·synchronized·
无名-CODING15 分钟前
Tomcat 底层核心知识点字典(面试必备)
java·面试·tomcat
XiYang-DING18 分钟前
【Java SE】双亲委派模型
java·开发语言
安之若素.re18 分钟前
918. 环形子数组的最大和
算法
阿阿阿阿里郎21 分钟前
ROS2快速入门--C++基础
开发语言·c++·算法