博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode1038. Binary Search Tree to Greater Sum Tree(思路及python解法)
阅读量:2242 次
发布时间:2019-05-09

本文共 748 字,大约阅读时间需要 2 分钟。

Given the root of a binary search tree with distinct values, modify it so that every node has a new value equal to the sum of the values of the original tree that are greater than or equal to node.val.

Example 1:

Input: [4,1,6,0,2,5,7,null,null,null,3,null,null,null,8]Output: [30,36,21,36,35,26,15,null,null,null,33,null,null,null,8]

看题介绍不是很明白,不过看图就懂了。就是遍历右子树、根节点、左子树,然后逐步val相加。

用dfs的方法,先遍历右子树,找到最右下角的node,然后再找他的跟节点,然后再遍历左子树。

用sum记录遍历过节点val的和,然后再赋值给当前节点即可。

class Solution:    def bstToGst(self, root: TreeNode) -> TreeNode:        self.sum=0        self.dfs(root)        return root    def dfs(self, root):        if root is None:return root        self.dfs(root.right)        self.sum+=root.val        root.val=self.sum        self.dfs(root.left)

 

转载地址:http://tjrbb.baihongyu.com/

你可能感兴趣的文章
Intellij IDEA使用(六)—— 使用Intellij IDEA创建Java项目并配置jar包
查看>>
Eclipse使用(十)—— 使用Eclipse创建简单的Maven Java项目
查看>>
Eclipse使用(十一)—— 使用Eclipse创建简单的Maven JavaWeb项目
查看>>
Intellij IDEA使用(十三)—— 在Intellij IDEA中配置Maven
查看>>
面试题 —— 关于main方法的十个面试题
查看>>
集成测试(一)—— 使用PHP页面请求Spring项目的Java接口数据
查看>>
使用Maven构建的简单的单模块SSM项目
查看>>
Intellij IDEA使用(十四)—— 在IDEA中创建包(package)的问题
查看>>
FastDFS集群架构配置搭建(转载)
查看>>
HTM+CSS实现立方体图片旋转展示效果
查看>>
FFmpeg 命令操作音视频
查看>>
问题:Opencv(3.1.0/3.4)找不到 /opencv2/gpu/gpu.hpp 问题
查看>>
目的:使用CUDA环境变量CUDA_VISIBLE_DEVICES来限定CUDA程序所能使用的GPU设备
查看>>
问题:Mysql中字段类型为text的值, java使用selectByExample查询为null
查看>>
程序员--学习之路--技巧
查看>>
解决问题之 MySQL慢查询日志设置
查看>>
contOS6 部署 lnmp、FTP、composer、ThinkPHP5、docker详细步骤
查看>>
TP5.1模板布局中遇到的坑,配置完不生效解决办法
查看>>
PHPstudy中遇到的坑No input file specified,以及传到linux环境下遇到的坑,模板文件不存在
查看>>
TP5.1事务操作和TP5事务回滚操作多表
查看>>