力扣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;
    }
}
相关推荐
不吃鱼的羊12 小时前
DaVinci Developer自动连接
java·开发语言
farerboy12 小时前
15-Java while 和 do...while循环
java·后端
菜菜的顾清寒12 小时前
力扣HOT100(50)动态规划-零钱兑换
算法·leetcode·动态规划
在繁华处12 小时前
Java从零到熟练(十二):Java与AI工具整合
java·人工智能·python
周末也要写八哥12 小时前
三分钟读懂:如何解决做题数量不足的问题?
算法
8Qi812 小时前
LeetCode 148. 排序链表 —— 解法二:自底向上归并(迭代,O(1) 空间)
数据结构·算法·leetcode·链表·归并·迭代
凯瑟琳.奥古斯特12 小时前
力扣1235完整解法详解
java·开发语言·leetcode
嘿黑嘿呦12 小时前
数据结构-图论-最小生成树
数据结构·算法·图论
quan_泉12 小时前
DIDCTF 取证初学者
java·服务器·前端
i220818 Faiz Ul13 小时前
民谣网站|基于Springboot的民谣网站管理系统(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·民谣网站