题目:
给定一个二叉搜索树(Binary Search Tree),把它转换成为累加树(Greater Tree),使得每个节点的值是原来的节点值加上所有大于它的节点值之和。
例如:
输入: 原始二叉搜索树: 5 / \ 2 13 输出: 转换为累加树: 18 / \ 20 13
思路:
二叉搜索树中序遍历的结果是从小到大的序列,这里我们可以倒着进行中序遍历,后面节点的和都会累加到当前的节点上去,定义一个成员变量对遍历节点的值进行累加就可以了。
代码:
/**
* 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 {
private:
int sum = 0;
void search(TreeNode* root)
{
if (root == nullptr) return;
if (root->right)
convertBST(root->right);
sum += root->val;
root->val = sum;
if (root->left)
convertBST(root->left);
}
public:
TreeNode* convertBST(TreeNode* root) {
if (root == nullptr)
return nullptr;
search(root);
return root;
}
};