108. 将有序数组转换为二叉搜索树

复制代码
https://leetcode.cn/problems/convert-sorted-array-to-binary-search-tree/description/?envType=study-plan-v2&envId=top-interview-150

这题考察的就是平衡二叉树的构建,所以需要掌握这部分的知识,如果对这方面知识有所欠缺的话可以看一下这篇博客:二叉搜索树/平衡二叉搜索树-CSDN博客

推销一下自己写的文章,我觉得我写的还是很详细的,认真看完的话这题就没什么问题了。

java 复制代码
class Solution {
    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;
        }
    }
    public TreeNode sortedArrayToBST(int[] nums) {
        TreeNode root = null;
        for(int i = 0; i < nums.length; i++) {
            root = addNode(root, nums[i]);
        }
        return root;
    }

    //计算树的高度
    public int height(TreeNode node) {//叶节点的高度为1
        if(node == null) return 0;
        return Math.max(height(node.left), height(node.right)) + 1;
    }
    //计算平衡因子(左子树的高度 - 右子树的高度)
    public int balanceFactor(TreeNode node) {
        return height(node.left) - height(node.right);
    }

    //左旋
    public TreeNode leftRotate(TreeNode node) {
        TreeNode right = node.right;
        node.right = null; // 断开连接,不然会产生环
        if(right.left != null) node.right = right.left;
        right.left = node;
        return right;
    }
    //右旋
    public TreeNode rightRotate(TreeNode node) {
        TreeNode left = node.left;
        node.left = null; // 断开连接,不然会产生环
        if(left.right != null) node.left = left.right;
        left.right = node;
        return left;
    }

    //添加节点
    public TreeNode addNode(TreeNode node, int val) {
        if(node == null) {
            return new TreeNode(val);
        }
        if(val < node.val) node.left = addNode(node.left, val);
        else if(val > node.val) node.right = addNode(node.right, val);
        // 插入节点后检查是否需要平衡调整
        int balanceFactor = balanceFactor(node);
        if(balanceFactor > 1 && val < node.left.val) {//LL情况->右旋,node是被破坏节点,加入节点是破坏节点
            return rightRotate(node);
        }
        if(balanceFactor < -1 && val > node.right.val) {//RR情况->左旋
            return leftRotate(node);
        }
        if(balanceFactor > 1 && val > node.left.val) {//LR情况->被破坏节点的左节点左旋,被破坏节点右旋
            node.left = leftRotate(node.left);
            return rightRotate(node);
        }
        if(balanceFactor < -1 && val < node.right.val) {//RL情况->被破坏节点的右节点右旋,被破坏节点左旋
            node.right = rightRotate(node.right);
            return leftRotate(node);
        }
        return node;
    }

    public static void main(String[] args) {
        Solution solution = new Solution();
        int[] nums = {-10,-3,0,5,9};
        solution.sortedArrayToBST(nums);
    }
}
相关推荐
IT利刃出鞘5 分钟前
Intellij Idea--解决Cannot download “https://start.spring.io‘: Connect timedout
java·ide·intellij-idea
中国lanwp16 分钟前
Spring 全局异常处理机制:多个 @ControllerAdvice 与重复 @ExceptionHandler
java·数据库·spring
Ashlee_code17 分钟前
关税战火中的技术方舟:新西兰证券交易所的破局之道 ——从15%关税冲击到跨塔斯曼结算联盟,解码下一代交易基础设施
java·python·算法·金融·架构·系统架构·区块链
桦01 小时前
【整数转罗马数字】
算法·leetcode
东东最爱敲键盘2 小时前
数据结构: 双向链表
数据结构
hqxstudying2 小时前
SpringBoot启动项目详解
java·spring boot·后端
你我约定有三2 小时前
分布式微服务--Nacos作为配置中心(补)关于bosststrap.yml与@RefreshScope
java·分布式·spring cloud·微服务·架构
keepDXRcuriosity3 小时前
IDEA识别lombok注解问题
java·ide·intellij-idea
酷飞飞3 小时前
C语言的复合类型、内存管理、综合案例
java·c语言·前端
宸津-代码粉碎机4 小时前
LLM 模型部署难题的技术突破:从轻量化到分布式推理的全栈解决方案
java·大数据·人工智能·分布式·python