LeetCode如何把二叉搜索树转换为累加树
发表于:2024-11-30 作者:千家信息网编辑
千家信息网最后更新 2024年11月30日,这篇文章主要介绍了LeetCode如何把二叉搜索树转换为累加树,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1,问题简述给出二叉 搜索
千家信息网最后更新 2024年11月30日LeetCode如何把二叉搜索树转换为累加树
这篇文章主要介绍了LeetCode如何把二叉搜索树转换为累加树,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
1,问题简述
给出二叉 搜索 树的根节点,该树的节点值各不相同,请你将其转换为累加树(Greater Sum Tree),使每个节点 node 的新值等于原树中大于或等于 node.val 的值之和。提醒一下,二叉搜索树满足下列约束条件:节点的左子树仅包含键 小于 节点键的节点。节点的右子树仅包含键 大于 节点键的节点。左右子树也必须是二叉搜索树。
2,示例
输入:[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 和 100 之间。
每个节点的值介于 0 和 100 之间。
树中的所有值 互不相同 。
给定的树为二叉搜索树。
3,题解思路
写了最基本的思路来解决,先统计二叉树的节点数据,然后根据题目的已知条件进行计算,数据赋值就可以了
4,题解程序
import java.util.ArrayList;
import java.util.List;
public class ConvertBSTTest {
static List
list = new ArrayList<>();
public static void main(String[] args) {
TreeNode t1 = new TreeNode(4);
TreeNode t2 = new TreeNode(1);
TreeNode t3 = new TreeNode(6);
TreeNode t4 = new TreeNode(0);
TreeNode t5 = new TreeNode(2);
TreeNode t6 = new TreeNode(5);
TreeNode t7 = new TreeNode(7);
TreeNode t8 = new TreeNode(3);
TreeNode t9 = new TreeNode(8);
t1.left = t2;
t1.right = t3;
t2.left = t4;
t2.right = t5;
t3.left = t6;
t3.right = t7;
t5.right = t8;
t7.right = t9;
TreeNode treeNode = convertBST(t1);
System.out.println("treeNode = " + treeNode);
}
public static TreeNode convertBST(TreeNode root) {
if (root == null) {
return null;
}
if (list.size() == 0) {
dfs(root);
}
Integer compute = compute(root.val);
root.val = compute;
if (root.left != null) {
convertBST(root.left);
}
if (root.right != null) {
convertBST(root.right);
}
return root;
}
private static Integer compute(Integer val) {
int sum = 0;
for (int num : list) {
if (num > val) {
sum += num;
}
}
sum += val;
return sum;
}
private static void dfs(TreeNode root) {
if (root == null) {
return;
}
if (root.left != null) {
dfs(root.left);
}
list.add(root.val);
if (root.right != null) {
dfs(root.right);
}
}
}
5,题解程序图片版
6
感谢你能够认真阅读完这篇文章,希望小编分享的"LeetCode如何把二叉搜索树转换为累加树"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!
节点
搜索
示例
篇文章
输入
输出
题解
子树
相同
之间
思路
数据
条件
程序
之和
价值
兴趣
同时
图片
更多
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全病毒种类
全国电信网络安全管理条例
北京触通无线网络技术有限公司
信息安全网络安全应急演练总结
战神引擎数据库端口不一致怎么办
光学设计和软件开发
数据库错删整个数据库
深圳尚游网络技术
云服务器能翻墙吗
struts数据库查询
g7服务器怎么升级大硬盘
想从事网络安全入门
btav资源服务器
孝感移动服务器升级
信息系统软件开发方法
服务器保存不了密码
包商银行软件开发 在哪里
宜昌找铺网络技术服务
服务器可以干什么
手机给服务器上网
无限软件开发费用是多少
武汉国家网络安全人才与创新
花都网络安全服务价格是怎样的
svn服务器版本回退
excel 表格与数据库
窗体连接数据库的代码
数据库商店管理系统主键外键
找网络技术总监运营总监
2008服务器数据库
公务员和软件开发有关岗位