1 Star 0 Fork 0

ZENGWatermelon/LeetCode

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
538.把二叉搜索树转换为累加树.py 1.27 KB
一键复制 编辑 原始数据 按行查看 历史
sunzhaoc 提交于 2020-12-02 22:40 . master
'''
Description:
Version: 1.0
Author: Vicro
Date: 2020-12-02 21:35:01
LastEditTime: 2020-12-02 22:12:52
FilePath: \Leetcode\538.把二叉搜索树转换为累加树.py
'''
#
# @lc app=leetcode.cn id=538 lang=python3
#
# [538] 把二叉搜索树转换为累加树
#
# @lc code=start
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
"""
Accept 77.64 5
中序遍历(倒序):定义的res为int
"""
class Solution:
def convertBST(self, root: TreeNode) -> TreeNode:
res = 0
res = self.dfs(root, res)
return root
def dfs(self, node, res):
if not node: return res
res = self.dfs(node.right, res)
res += node.val
node.val = res
res = self.dfs(node.left, res)
return res
"""
Accept 31.77 13.66
中序遍历(倒序):定义的res为列表
"""
class Solution:
def convertBST(self, root: TreeNode) -> TreeNode:
res = [0]
self.dfs(root, res)
return root
def dfs(self, node, res):
if not node: return
self.dfs(node.right, res)
res[0] += node.val
node.val = res[0]
self.dfs(node.left, res)
# @lc code=end
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/watermelonTT/LeetCode.git
git@gitee.com:watermelonTT/LeetCode.git
watermelonTT
LeetCode
LeetCode
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385