Leetcode面试经典150题-108.将有序数组转换为二叉搜索树

解法都在代码里,不懂就留言或者私信

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    /**二叉搜索树的特征:某个节点的左子树的所有节点都小于它,右子树的所有节点的值都大于它
    我们先找到中间的那个数的下标mid,然后0~mid-1 构造左子树,mid+1~end构造右子树 */
    public TreeNode sortedArrayToBST(int[] nums) {
        TreeNode root = generateBST(nums, 0, nums.length - 1);
        return root;
    }

    public TreeNode generateBST(int[] nums, int left, int right) {
        /**没有数别捣乱了 */
        if(left > right) {
            return null;
        }
        /**如果就一个数,那就构造呗 */
        if(left == right) {
            return new TreeNode(nums[left]);
        }
        /**大于1个数找到中间那个点 */
        int mid = left + ((right - left) >> 1);
        /**构造根节点 */
        TreeNode root = new TreeNode(nums[mid]);
        /**左边是它的左子树 */
        root.left = generateBST(nums, left, mid - 1);
        /**右边是它的右子树 */
        root.right = generateBST(nums, mid + 1, right);
        return root;
    }
}

运行结果,规定压栈占空间,这里可以优化,我时间不够就算了

相关推荐
GUIQU.7 分钟前
【每日一题 | 2025年5.5 ~ 5.11】搜索相关题
算法·每日一题·坚持
不知名小菜鸡.7 分钟前
记录算法笔记(2025.5.13)二叉树的最大深度
笔记·算法
小雅痞8 分钟前
[Java][Leetcode middle] 55. 跳跃游戏
java·leetcode
uperficialyu32 分钟前
2025年01月10日浙江鑫越系统科技前端面试
前端·科技·面试
真的想上岸啊36 分钟前
c语言第一个小游戏:贪吃蛇小游戏05
c语言·算法·链表
元亓亓亓1 小时前
LeetCode热题100--206.反转链表--简单
算法·leetcode·链表
边跑边掩护1 小时前
LeetCode 373 查找和最小的 K 对数字题解
leetcode
诚丞成1 小时前
BFS算法篇——从晨曦到星辰,BFS算法在多源最短路径问题中的诗意航行(上)
java·算法·宽度优先
hongjianMa1 小时前
2024睿抗编程赛国赛-题解
算法·深度优先·图论·caip
czy87874752 小时前
两种常见的C语言实现64位无符号整数乘以64位无符号整数的实现方法
c语言·算法