力扣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 小时前
C++算法:链表
c++·算法·链表
星环科技13 小时前
数据标准Agent ,让企业数据说同一种语言
java·开发语言·前端
凌波粒13 小时前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode
SimonKing13 小时前
Qoder 提供免费 Qwen3.7-Max,无需订阅
java·后端·程序员
旖-旎13 小时前
《LeetCode 417 太平洋大西洋水流问题 FloodFill DFS 解法》
c++·算法·深度优先·力扣·floodfill
凌波粒13 小时前
LeetCode--46.全排列(回溯算法)
数据结构·算法·leetcode
dadaobusi13 小时前
RISC-V 虚拟化:虚拟机TLB处理
java·开发语言
程序猿乐锅13 小时前
【 苍穹外卖day03 | 菜品管理 】
java·开发语言·数据库·mysql
雾削木13 小时前
B语言经典教程现代化重构
java·前端·stm32·单片机·嵌入式硬件
2zcode13 小时前
项目文档:基于MATLAB语音信号变声算法设计与实现
算法·matlab·语音识别