LeetCode如何把二叉搜索树转换为累加树
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,这篇文章主要介绍了LeetCode如何把二叉搜索树转换为累加树,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1,问题简述给出二叉 搜索
千家信息网最后更新 2025年01月31日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安全错误
数据库的锁怎样保障安全
崔腾崔翔 网络安全
服务器运行状态是什么意思
cbm是英文数据库么
性能测试网络安全专业
软件开发公司可以开什么品名
前端服务器的运维管理
服务器可以用cpu虚拟显卡么
服务器安全防范流程
音频云服务器
云南软件开发公司
网络安全监察总队长
三门峡软件开发定制
上海诚信积分管理软件开发系统
黄岛区管理系统软件开发解决方案
战地5怎样选择服务器
工行软件开发中心罗立为
sdn网络技术的优点
学网络安全必须会英语吗
北京服务器租用方案云主机
绵阳软件开发学校
普通网站怎么选服务器
京东软件开发实习生天天上班吗
hp服务器 安装手册
君容系统未和服务器建立信任关系
山东特色软件开发技术指导
山东瑞希互联网科技公司怎么样
加强网络安全教育的宣传
asp 文本框添加到数据库两次
共同筑牢网络安全防线总结
备份mysql数据库影响性能