leetcode 1038. 从二叉搜索树到更大和树
生活随笔
收集整理的這篇文章主要介紹了
leetcode 1038. 从二叉搜索树到更大和树
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
目錄
- 題目描述:
- 示例:
- 解法:
題目描述:
給出二叉搜索樹(shù)的根節(jié)點(diǎn),該二叉樹(shù)的節(jié)點(diǎn)值各不相同,修改二叉樹(shù),使每個(gè)節(jié)點(diǎn) node?的新值等于原樹(shù)中大于或等于?node.val?的值之和。
提醒一下,二叉搜索樹(shù)滿足下列約束條件:
- 節(jié)點(diǎn)的左子樹(shù)僅包含鍵小于節(jié)點(diǎn)鍵的節(jié)點(diǎn)。
- 節(jié)點(diǎn)的右子樹(shù)僅包含鍵大于節(jié)點(diǎn)鍵的節(jié)點(diǎn)。
- 左右子樹(shù)也必須是二叉搜索樹(shù)。
?
示例:
輸入:[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]提示:
- 樹(shù)中的節(jié)點(diǎn)數(shù)介于 1 和 100 之間。
- 每個(gè)節(jié)點(diǎn)的值介于?0 和?100?之間。
- 給定的樹(shù)為二叉搜索樹(shù)。
解法:
/*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/ class Solution { public:int updateTree(TreeNode*& root, int val){if(root == NULL){return val;}else{int right = updateTree(root->right, val);root->val += right;int left = updateTree(root->left, root->val);return left;}}TreeNode* bstToGst(TreeNode* root) {int val = 0;updateTree(root, val);return root;} };轉(zhuǎn)載于:https://www.cnblogs.com/zhanzq/p/11075889.html
總結(jié)
以上是生活随笔為你收集整理的leetcode 1038. 从二叉搜索树到更大和树的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: IOS-UITextField类
- 下一篇: Zend Framework学习之Zen