力扣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;
    }
}
相关推荐
小白菜又菜13 小时前
Leetcode 3432. Count Partitions with Even Sum Difference
算法·leetcode
wuhen_n14 小时前
LeetCode -- 15. 三数之和(中等)
前端·javascript·算法·leetcode
sin_hielo14 小时前
leetcode 2483
数据结构·算法·leetcode
Nonoas14 小时前
动态代理:发布订阅的高级玩法
java·ide·intellij-idea
程序员-周李斌15 小时前
Java 死锁
java·开发语言·后端
Xの哲學15 小时前
Linux多级时间轮:高精度定时器的艺术与科学
linux·服务器·网络·算法·边缘计算
大头流矢15 小时前
归并排序与计数排序详解
数据结构·算法·排序算法
油泼辣子多加15 小时前
【信创】算法开发适配
人工智能·深度学习·算法·机器学习
皮皮林55115 小时前
Prometheus+Grafana,打造强大的监控与可视化平台
java
JasmineWr16 小时前
CompletableFuture相关问题
java·开发语言