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);
    }
}
相关推荐
且听风吟ayan3 分钟前
leetcode day20 滑动窗口209+904
算法·leetcode·c#
m0_675988234 分钟前
Leetcode350:两个数组的交集 II
算法·leetcode·数组·哈希表·python3
_Itachi__5 分钟前
LeetCode 热题 100 160. 相交链表
算法·leetcode·链表
m0_675988237 分钟前
Leetcode1206:设计跳表
算法·leetcode·跳表·python3
冠位观测者9 分钟前
【Leetcode 每日一题 - 扩展】1512. 好数对的数目
数据结构·算法·leetcode
Joyner20189 分钟前
python-leetcode-路径总和 III
算法·leetcode·职场和发展
南宫生9 分钟前
力扣每日一题【算法学习day.133】
java·学习·算法·leetcode
_Itachi__11 分钟前
LeetCode 热题 100 560. 和为 K 的子数组
数据结构·算法·leetcode
夏末秋也凉11 分钟前
力扣-贪心-55 跳跃游戏
算法·leetcode·游戏
獨枭11 分钟前
如何在 Mac 上安装并配置 JDK 环境变量
java·macos·jdk