leetcode做题笔记1038. 从二叉搜索树到更大和树

给定一个二叉搜索树 root (BST),请将它的每个节点的值替换成树中大于或者等于该节点值的所有节点值之和。

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

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

示例 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]

思路一:递归

c++解法

cpp 复制代码
class Solution {
public:

    int find(TreeNode* root,int val)
    {
        if(!root) return 0;
        int res = 0;
        res += find(root->right,val);
        res += root->val;
        root->val = res + val;
        res += find(root->left,root->val);
        return res;
    }

    TreeNode* bstToGst(TreeNode* root) {
        find(root,0);
        return root;
    }
};
相关推荐
不会代码的小猴4 小时前
Linux环境编程第六天笔记--system-V IPC
linux·笔记
乌恩大侠5 小时前
【笔记】USRP 5G 和 6G 参考架构
笔记·5g
biuyyyxxx5 小时前
Python自动化办公学习笔记(一) 工具安装&教程
笔记·python·学习·自动化
舟舟亢亢6 小时前
Java集合笔记总结
java·笔记
A_nanda6 小时前
c# MOdbus rto读写串口,如何不相互影响
算法·c#·多线程
丝斯20116 小时前
AI学习笔记整理(66)——多模态大模型MOE-LLAVA
人工智能·笔记·学习
代码雕刻家8 小时前
2.4.蓝桥杯-分巧克力
算法·蓝桥杯
kida_yuan8 小时前
【Linux】运维实战笔记 — 我常用的方法与命令
linux·运维·笔记
Ulyanov8 小时前
顶层设计——单脉冲雷达仿真器的灵魂蓝图
python·算法·pyside·仿真系统·单脉冲
laplace01238 小时前
Claude Skills 笔记整理
人工智能·笔记·agent·rag·skills