力扣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;
    }
}
相关推荐
dunky5 分钟前
副本机制与 ISR 设计:为什么 Kafka 这么快又这么可靠
java
夕除11 分钟前
spring boot 9
java·mysql·spring
执明wa15 分钟前
从 T 到协变逆变
java·开发语言·数据结构
XiYang-DING20 分钟前
【Java EE】 TCP—异常情况处理
java·tcp/ip·java-ee
lianghyan21 分钟前
List.stream().min
java·开发语言
阿Y加油吧23 分钟前
两道数组算法题复盘:多数元素 & 颜色分类
算法·leetcode·职场和发展
爱笑的源码基地1 小时前
小微企业ERP源码,采用SpringBoot+Vue+ElementUI+UniAPP技术架构,支持二次开发及商用授权
java·源码·二次开发·erp·源代码·mrp生产计划
夏日听雨眠1 小时前
排序(选择排序 ,冒泡排序,归并排序)
数据结构·算法·排序算法
happymaker06261 小时前
Spring学习日记——DAY03(yml文件)
java·spring boot·spring
凯瑟琳.奥古斯特1 小时前
操作系统核心结构解析
java·开发语言·c++·python·职场和发展