Leetcode 538:把二叉搜索树转化为累加树

给出二叉搜索 树的根节点,该树的节点值各不相同,请你将其转换为累加树(Greater Sum Tree),使每个节点 node 的新值等于原树中大于或等于 node.val 的值之和。

解题思路:

其实就是相当于反中序遍历,然后当前结点的值加上之前遍历结点值的和。

java 复制代码
public class title538 {

    int sum=0;   //sum为之前节点的和
    public TreeNode convertBST(TreeNode root) {
        traversal(root);
        return root;
    }

    //反中序遍历
    public void traversal(TreeNode root){
        if(root==null) return;
        //遍历顺序为 右,中,左
        traversal(root.right);
        root.val=root.val+sum;
        sum=root.val;
        traversal(root.left);
    }
}
相关推荐
CoovallyAIHub15 分钟前
模糊、噪声、压缩……让检测器学会主动评估画质
深度学习·算法·计算机视觉
Cg1362691597416 分钟前
HTML标题标签
java
feathered-feathered19 分钟前
测试实战【用例设计】自己写的项目+功能测试(1)
java·服务器·后端·功能测试·jmeter·单元测试·压力测试
洋洋技术笔记22 分钟前
Spring Boot自动装配原理
java·spring boot
跃龙客31 分钟前
atomic笔记
笔记·算法
iameyama39 分钟前
Amazon Redshift 和 BigQuery 数据类型区别
java·开发语言
智驱力人工智能41 分钟前
地铁隧道轨道障碍物实时检测方案 守护城市地下动脉的工程实践 轨道障碍物检测 高铁站区轨道障碍物AI预警 铁路轨道异物识别系统价格
人工智能·算法·yolo·目标检测·计算机视觉·边缘计算
-孤存-44 分钟前
Spring Bean作用域与生命周期全解析
java·开发语言·前端
陈天伟教授44 分钟前
人工智能应用- 预测化学反应:05. AI 预测化学反应类型
人工智能·深度学习·学习·算法·机器学习