剑指Offer || 054.把二叉搜索树转换为累加树

题目

给定一个二叉搜索树,请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。

提醒一下,二叉搜索树满足下列约束条件:

  • 节点的左子树仅包含键小于节点键的节点。
  • 节点的右子树仅包含键大于 节点键的节点。
  • 左右子树也必须是二叉搜索树。

示例 1:

复制代码
输入:root=[4,1,6,0,2,5,7,null,null,null,3,null,null,null,8]
输出:[30,36,21,36,35,26,15,null,null,null,33,null,null,null,8]

示例 2:

复制代码
输入:root = [0,null,1]
输出:[1,null,1]

示例 3:

复制代码
输入:root = [1,0,2]
输出:[3,3,2]

示例 4:

复制代码
输入:root = [3,2,4,1]
输出:[7,9,4,10]

提示:

  • 树中的节点数介于 0104 之间。
  • 每个节点的值介于 -104104 之间。
  • 树中的所有值 互不相同
  • 给定的树为二叉搜索树。

注意:

LCR 054. 把二叉搜索树转换为累加树 - 力扣(LeetCode)

题解

思路一:两次dfs,第一次计算出sum,第二次中序遍历,将sum传给t.val,然后sum-=t.val

代码:

java 复制代码
class Solution {
	int sum=0;
    public TreeNode convertBST(TreeNode root) {
    	if(root==null) return null;
    	dfs(root);
    	dfs2(root);
    	return root;
    }
    
    public void dfs(TreeNode t) {
    	if(t.left!=null) dfs(t.left);
    	sum+=t.val;
    	if(t.right!=null) dfs(t.right);
    }
    public void dfs2(TreeNode t) {
    	if(t.left!=null) dfs2(t.left);
    	int tmp=t.val;
    	t.val=sum;
    	sum-=tmp;
    	if(t.right!=null) dfs2(t.right);
    }
}

思路二:中序遍历的倒序,每次遍历到TreeNode时sum+=t.val,然后t.val=sum

代码:

java 复制代码
class Solution {
	int sum=0;
    public TreeNode convertBST(TreeNode root) {
    	if(root==null) return null;
    	dfs(root);
    	return root;
    }
    
    public void dfs(TreeNode t) {
    	if(t.right!=null) dfs(t.right);
    	sum += t.val;
        t.val = sum;
    	if(t.left!=null) dfs(t.left);
    }
}
相关推荐
mm-q291522272926 分钟前
【天野学院5期】 第5期易语言半内存辅助培训班,主讲游戏——手游:仙剑奇侠传4,端游:神魔大陆2
人工智能·算法·游戏
MoRanzhi120332 分钟前
Python 实现:从数学模型到完整控制台版《2048》游戏
数据结构·python·算法·游戏·数学建模·矩阵·2048
2401_841495641 小时前
【数据结构】基于BF算法的树种病毒检测
java·数据结构·c++·python·算法·字符串·模式匹配
蒙奇D索大1 小时前
【算法】递归算法实战:汉诺塔问题详解与代码实现
c语言·考研·算法·面试·改行学it
一只鱼^_1 小时前
力扣第 474 场周赛
数据结构·算法·leetcode·贪心算法·逻辑回归·深度优先·启发式算法
叫我龙翔2 小时前
【数据结构】从零开始认识图论 --- 单源/多源最短路算法
数据结构·算法·图论
深圳佛手2 小时前
几种限流算法介绍和使用场景
网络·算法
陌路203 小时前
S14排序算法--基数排序
算法·排序算法
ysa0510303 小时前
虚拟位置映射(标签鸽
数据结构·c++·笔记·算法
Yue丶越3 小时前
【C语言】深入理解指针(二)
c语言·开发语言·数据结构·算法·排序算法