力扣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;
    }
}
相关推荐
申克Lab16 分钟前
STM32 FreeRTOS 消息队列
java·stm32·嵌入式硬件
敲敲千反田20 分钟前
多线程复习
java·开发语言
lihao lihao21 分钟前
c++红黑树
算法
Sarvartha21 分钟前
递推与递归笔记
算法
TracyCoder1231 小时前
LeetCode Hot100(1/100)——1. 两数之和 (Two Sum)
算法·leetcode
敲敲了个代码1 小时前
多标签页强提醒不重复打扰:从“弹框轰炸”到“共享待处理队列”的实战
java·前端·javascript·面试·架构
Jackson@ML1 小时前
2026最新版Eclipse for Java安装使用指南
java·ide·eclipse
进击的小头1 小时前
常用数字滤波器的特性与适用场景
c语言·算法
莫问前路漫漫1 小时前
JDK 核心实操指南:从安装配置到项目打包调试全流程
java·jdk
Getgit1 小时前
Linux系统的特点有哪些
java·linux·运维·网络·sql