leetcode-538. 把二叉搜索树转换为累加树

题目描述

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

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

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

注意: 本题和 1038: . - 力扣(LeetCode) 相同

示例 1:

复制代码
输入:[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]

思路

反序中序遍历,使用递归

唯一困难的地方:中间的两行代码

1)需要设置一个记录全局累加的变量

2)之后先更新这个变量,self.res += root.val

3)更新根节点的值:root.val = self.res

4)其他的只要先遍历右子树,再遍历左子树就行

python 复制代码
# Definition for a binary tree node.
# class TreeNode(object):
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution(object):
    def __init__(self):
        self.res = 0
    def convertBST(self, root):
        """
        :type root: TreeNode
        :rtype: TreeNode
        """
        if not root:
            return None
        if root.right:
            self.convertBST(root.right)
        self.res += root.val 
        root.val = self.res
        if root.left:
            self.convertBST(root.left)
        return root
相关推荐
保持低旋律节奏15 分钟前
算法——冗余!哈希表、vector、string适配器的混合使用
数据结构·算法·散列表
weixin_4577600042 分钟前
OpenCV 图像处理基础算法详解(一)
图像处理·opencv·算法
做怪小疯子1 小时前
LeetCode 热题 100——链表——相交链表
算法·leetcode·链表
while(努力):进步2 小时前
5G与物联网:连接万物的数字化未来
leetcode
立志成为大牛的小牛2 小时前
数据结构——五十一、散列表的基本概念(王道408)
开发语言·数据结构·学习·程序人生·算法·散列表
Coovally AI模型快速验证3 小时前
去噪扩散模型,根本不去噪?何恺明新论文回归「去噪」本质
人工智能·深度学习·算法·机器学习·计算机视觉·数据挖掘·回归
歌_顿3 小时前
attention、transform、bert 复习总结 1
人工智能·算法
MicroTech20253 小时前
MLGO微算法科技时空卷积与双重注意机制驱动的脑信号多任务分类算法
科技·算法·分类
txp玩Linux4 小时前
rk3568上解析webrtc音频降噪算法处理流程
算法·音视频·webrtc
立志成为大牛的小牛4 小时前
数据结构——五十二、散列函数的构造(王道408)
数据结构·笔记·程序人生·考研·算法