力扣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;
    }
}
相关推荐
我是无敌小恐龙1 分钟前
Java SE 零基础入门 Day02 运算符与流程控制超详细笔记
java·数据结构·spring boot·笔记·python·spring·spring cloud
invicinble3 分钟前
对于代码阅读能力的思考和总结
java
jrlong3 分钟前
HelloAgents 进阶篇 task03
java·前端·python
talen_hx2968 分钟前
飞书机器人发文本消息
java·前端·飞书
pearlthriving9 分钟前
STL容器及其底层
开发语言·c++·算法
2601_9498165810 分钟前
Spring Boot--@PathVariable、@RequestParam、@RequestBody
java·spring boot·后端
念越10 分钟前
算法每日一题 Day04|快慢双指针法解决环形链表问题
数据结构·算法·链表
张人玉13 分钟前
VisionPro 药物检测工具 学习笔记
算法·c#·机器视觉·vsionpro
_深海凉_15 分钟前
LeetCode热题100-前 K 个高频元素
算法·leetcode·职场和发展
沐风。5615 分钟前
python
java·服务器·python