代码随想录算法刷题训练营day23

代码随想录算法刷题训练营day23:LeetCode(669)修剪二叉搜索树、LeetCode(108)将有序数组转换为二叉搜索树、LeetCode(538)把二叉树转化为累加树

LeetCode(669)修剪二叉搜索树
题目

代码

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 {
    public TreeNode trimBST(TreeNode root, int low, int high) {
        //注意是二叉搜索树,一定要按二叉搜索树的规则来做
        //采用先序递归的方法来做
        //判断终止条件-----返回为null
        if(root==null){
            return null;
        }
        //判断树的节点是否在区间里面,若树的节点不在区间则进行删除-----根节点被删除的情况,判断左右子树的保留情况
        if(root.val<low){//仅会出现一种情况
            //那么此时这颗以root为根树的左子树一定不保留,右子树可能保留,也可能不保留,需要对右子树进行判断
            TreeNode right=trimBST(root.right, low, high);
            return right;//此时直接将右子树判断的结果返回----直接返回,后面能接住
        }
        if(root.val>high){//进入之后直接把左节点返回回去了,相当于把节点直接删除了
            //那么此时这颗树的右子树一定不保留,左子树可能保留,需要对左子树进行判断
            TreeNode left=trimBST(root.left, low, high);
            return left;
        }
        //递归程序开始,采用先序遍历,采用根左右的方法
        root.left=trimBST(root.left, low, high);//左边树处理后返回根节点
        root.right=trimBST(root.right, low, high);//右边树处理后返回根节点
        return root;

    }
}

LeetCode(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 {
    public TreeNode sortedArrayToBST(int[] nums) {
        //构造平衡二叉树-------思路,主要是切割区间----注意切割区间的终止条件
        //定义一个新的构建二叉树的方法,用于构建新的二叉树
        int left=0;//定义左参数,左区间
        int right=nums.length-1;
        TreeNode root=buildTreeNode(nums,left,right);
        return root;
    }
    //定义构建平衡二叉树的方法
    public TreeNode buildTreeNode(int[] nums,int left,int right){
        //采用左闭右闭的方法
        //判断终止条件-----即为构建不了二叉树的方法
        if(left>right){
            return null;
        }
        //单次递归的执行策略
        int mid=(left+right)/2;
        TreeNode root=new TreeNode(nums[mid]);
        //递归----先序遍历---根左右
        root.left=buildTreeNode(nums, left, mid-1);//左子树
        root.right=buildTreeNode(nums, mid+1, right);//右子树
        return root;
    }
}

LeetCode(538)把二叉树转化为累加树
题目

代码

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 {
    int pre=0;
    public TreeNode convertBST(TreeNode root) {
        //回顾一下数组的操作方法,双指针
        //本题主要是更新节点的值
        updateTreeNodeVal(root);//将树的根节点传入进去
        //更新完成之后返回root
        return root;
    }
    public void updateTreeNodeVal(TreeNode root){
        //终止条件
        if(root==null){
            return;
        }
       
        updateTreeNodeVal(root.right);
        //中间节点的处理逻辑
        //此时到了最后一个节点值
        root.val=root.val+pre;//此时记录的是当前节点值
        pre=root.val;//要理解清楚,不要绕进去
        //第一个更新的是最右边-根-左
        updateTreeNodeVal(root.left);
    }
}
相关推荐
间彧2 小时前
SimpleDateFormat既然不推荐使用,为什么java 8+中不删除此类
java
间彧2 小时前
DateTimeFormatter相比SimpleDateFormat在性能上有何差异?
java
间彧2 小时前
为什么说SimpleDateFormat是经典的线程不安全类
java
MacroZheng2 小时前
横空出世!MyBatis-Plus 同款 ES ORM 框架,用起来够优雅!
java·后端·elasticsearch
CoovallyAIHub3 小时前
港大&字节重磅发布DanceGRPO:突破视觉生成RLHF瓶颈,多项任务性能提升超180%!
深度学习·算法·计算机视觉
用户0332126663673 小时前
Java 查找并替换 Excel 中的数据:详细教程
java
间彧3 小时前
ThreadLocal实现原理与应用实践
java
若水不如远方3 小时前
Netty的四种零拷贝机制:深入原理与实战指南
java·netty
用户7493636848433 小时前
【开箱即用】一分钟使用java对接海外大模型gpt等对话模型,实现打字机效果
java