【改造中序遍历算法】 LCR 054. 把二叉搜索树转换为累加树

LCR 054. 把二叉搜索树转换为累加树

解题思路

  • 改造中序遍历算法
  • 先遍历右子树 然后累加当前节点的值 再遍历左子树
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 convertBST(TreeNode root) {
        traverse(root);
        return root;
    }

    int sum = 0;

    public void traverse(TreeNode root){
        if(root == null){
            return ;
        }

        traverse(root.right);

        sum += root.val;
        root.val = sum;

        traverse(root.left);
    }
}
相关推荐
lkbhua莱克瓦246 分钟前
Java基础——常用算法3
java·数据结构·笔记·算法·github·排序算法·学习方法
小白程序员成长日记7 分钟前
2025.11.07 力扣每日一题
数据结构·算法·leetcode
·白小白9 分钟前
力扣(LeetCode) ——209. 长度最小的子数组(C++)
c++·算法·leetcode
小猪咪piggy11 分钟前
【算法】day16 动态规划
算法·动态规划
ohnoooo912 分钟前
251106 算法
数据结构·c++·算法
uesowys34 分钟前
华为OD算法开发指导-简易内存池
java·算法·华为od
Greedy Alg37 分钟前
LeetCode 155. 最小栈
算法
小白程序员成长日记1 小时前
2025.11.08 力扣每日一题
算法·leetcode·职场和发展
Nebula_g1 小时前
C语言应用实例:学生管理系统1(指针、结构体综合应用,动态内存分配)
c语言·开发语言·学习·算法·基础
小叮当⇔1 小时前
“征服式学习”提示词工具箱
学习·算法