力扣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;
    }
}
相关推荐
white-persist4 分钟前
差异功能定位解析:C语言与C++(区别在哪里?)
java·c语言·开发语言·网络·c++·安全·信息可视化
kokunka17 分钟前
C#类修饰符功能与范围详解
java·开发语言·c#
ShineWinsu23 分钟前
对于数据结构:链式二叉树的超详细保姆级解析—中
数据结构·c++·算法·面试·二叉树·校招·递归
仟濹28 分钟前
【Java 基础】3 面向对象 - this
java·开发语言·python
百***355139 分钟前
什么是Spring Boot 应用开发?
java·spring boot·后端
野蛮人6号44 分钟前
力扣热题100道之207课程表
算法·leetcode·职场和发展
学学学无无止境1 小时前
力扣-买卖股票的最佳时机
leetcode
这周也會开心1 小时前
Map的遍历方式
数据结构·算法
謝堆堆DDD1 小时前
eclipse由只运行java文件到创建web项目
java·ide·eclipse
无敌最俊朗@1 小时前
C++ 值类别与对象模型面试题(12)
算法