力扣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;
    }
}
相关推荐
Bechamz2 分钟前
大数据开发学习Day27
java·大数据·学习
Byron__8 分钟前
Java并发核心面试知识点
java·面试·多线程·并发编程
Java成神之路-10 分钟前
Java SPI vs Spring SPI
java·spring
希望永不加班12 分钟前
Java数据类型陷阱:int和Integer的7个关键区别
java·开发语言
boonya14 分钟前
Idea CC GUI插件如何通过 CC Switch 工具将 Claude Code 的后端配置为 DeepSeek 的 v4-pro 模型?
java·ide·intellij-idea
Dfreedom.16 分钟前
【实战篇】分类任务全流程演示——决策树
人工智能·算法·决策树·机器学习·分类
阿梦Anmory17 分钟前
【RAG相关】深入理解混合检索:BM25关键词检索与RRF融合算法详解
算法
浅念-23 分钟前
LeetCode最短路必看:BFS算法原理+经典题解
数据结构·c++·算法·leetcode·职场和发展·bfs·宽度优先
aqiu11111123 分钟前
ACM校赛
算法
花千树-01030 分钟前
从业务接口到 MCP Tool:多语言工程化实践指南(Python / TypeScript / Java)
java·python·rpc·typescript·api·mcp