LintCode 597.具有最大平均数的子树

给一棵二叉树,找到有最大平均值的子树。返回子树的根结点。

分治+遍历
分治即为在左右子树中找到有最大平均值的子树 再和整体进行比较
在分治的同时 保存每个根节点下的sum和size 同时进行打擂台比较
利用全局常量保存最大平均值以及对应根节点

public class Solution {
    
    class ResultType{
        double sum;
        int size;
        public ResultType(double sum, int size){
            this.sum = sum;
            this.size = size;
        }
    }
    private double maxAverage = -1.0 / 0;
    private TreeNode node;
    public TreeNode findSubtree2(TreeNode root) {
        helper(root);
        return node;

    }
    public ResultType helper(TreeNode root){
        if(root == null)
            return new ResultType(0,0);
        ResultType left = helper(root.left);
        ResultType right = helper(root.right);
        if((left.sum + right.sum + root.val) / (right.size + left.size + 1) > maxAverage){
            node = root;
            maxAverage = (left.sum + right.sum + root.val) / (right.size + left.size + 1);
        }
        return new ResultType(left.sum + right.sum + root.val, left.size + right.size + 1);

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值