前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >337. 打家劫舍 III

337. 打家劫舍 III

作者头像
名字是乱打的
发布2021-12-24 08:29:48
1850
发布2021-12-24 08:29:48
举报
文章被收录于专栏:软件工程

一 题目:

二 思路:

动态规划

这道题目和之前的打家劫舍1特别像,就是之前是一条链表街打劫,现在是一个二叉树打劫,都是一个相邻结点被触发的报警问题。

这题我们先分析一下,相邻结点不能被同时触发,也就是说父子结点不能被同时被偷

那么我们可以转换思路划分子问题为:

  • 当前结点被不被打劫
  • 当前结点被打劫

如果当前结点被打劫了,那么其孩子结点就不能有被打劫的,如果当前结点没被打劫,那么孩子结点就无所谓了。

这道题目的话我们就可以通过后续遍历的方法把所有可能情况进行向上的汇总,用下层多路的可能性去判断上层的可能收益问题;

三 代码:

代码语言:javascript
复制
 class Solution {
    public int rob(TreeNode root) {
        int[] res=dfs(root);
        return Math.max(res[0],res[1]);
    }


    /**
     * int[] 存储当前结点偷不偷的获益情况
     * 0代表不偷,1代表偷
     *
     */
    private int[] dfs(TreeNode root) {
        //空结点返回偷的结果集均为0,啥也没有
        if (root==null){
            return new int[]{0,0};
        }

        //左孩子偷不偷获益情况
        int[] leftDfs=dfs(root.left);
        //右孩子偷不偷获益情况
        int[] rightDfs=dfs(root.right);

        int[] curr=new int[2];
        //当前结点不偷
        curr[0]=Math.max(leftDfs[0],leftDfs[1])+Math.max(rightDfs[0],rightDfs[1]);
        //当前结点偷
        curr[1]=leftDfs[0]+rightDfs[0]+root.val;

        return curr;
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/12/13 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一 题目:
  • 二 思路:
  • 三 代码:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档