LeetCode第538题把二叉搜索树转换为累加树

本文详细介绍了如何将一个二叉搜索树转换为累加树,使得每个节点值等于其自身加上所有大于它的节点值之和。解题思路包括理解二叉搜索树的性质,并提出通过右根左的中序遍历来实现从大到小的排序,进而转换树的结构。提供了LeetCode第538题的解题代码链接。
摘要由CSDN通过智能技术生成
题目描述

给定一个二叉搜索树(Binary Search Tree),把它转换成为累加树(Greater Tree),使得每个节点的值是原来的节点值加上所有大于它的节点值之和。

解题思路

1、题意理解:
明确什么是二叉搜索树,任意结点的左子树比右子树小则为二叉搜索树
也就是说对于左子树来说,需要加上右子树的值和根节点的值
2、想法:
可以将二叉树排好序,如果我们希望每个结点只访问一次,排序的顺序是从大到小。如果使用中序遍历,我们可以得到从小到大的排序,中序遍历的顺序是left, root, right, 因此如果希望得到从大到小的排序,其结点的访问顺序是right,root, left。

代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    int  sum = 0;
    public TreeNode convertBST(TreeNode root) {
        convert(root);
        return root;
    }
    public void convert(TreeNode cur){
        if(cur == null){
            return;
        }
        convert(cur.right);
        cur.val = sum + cur.val;
        sum = cur.val;
        convert(cur.left);
    }
}

参考:https://leetcode.com/problems/convert-bst-to-greater-tree/discuss/100506/Java-Recursive-O(n)-time

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值