• 337. 打家劫舍 III


    在上次打劫完一条街道之后和一圈房屋后,小偷又发现了一个新的可行窃的地区。这个地区只有一个入口,我们称之为“根”。 除了“根”之外,每栋房子有且只有一个“父“房子与之相连。一番侦察之后,聪明的小偷意识到“这个地方的所有房屋的排列类似于一棵二叉树”。 如果两个直接相连的房子在同一天晚上被打劫,房屋将自动报警。

    计算在不触动警报的情况下,小偷一晚能够盗取的最高金额。

    示例 1:

    输入: [3,2,3,null,3,null,1]

    3
    /
    2 3

    3 1

    输出: 7
    解释: 小偷一晚能够盗取的最高金额 = 3 + 3 + 1 = 7.

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/house-robber-iii

     1 public class RootIII {
     2     static class TreeNode {
     3         int val;
     4         TreeNode left;
     5         TreeNode right;
     6         TreeNode(int x) {
     7             val = x;
     8         }
     9     }
    10     //总的来说,一种是带根节点的结果,一种是不带根节点的结果,但是在后面计算最大值时,
    11     //不一定值只隔一个偷,也有可能隔两个,所以对于每一个节点都进行该判断,返回其中的大值
    12     public int rob(TreeNode root) {
    13         if(root == null) {
    14             return 0;
    15         }
    16         int num1 = root.val;
    17         if(root.left != null) {
    18             num1 += rob(root.left.left) + rob(root.left.right);
    19         }
    20         if(root.right != null) {
    21             num1 += rob(root.right.left) + rob(root.right.right);
    22         }
    23         
    24         int num2 = rob(root.left) + rob(root.right);
    25         return Math.max(num1, num2);
    26     }
    27 }
    无论有多困难,都坚强的抬头挺胸,人生是一场醒悟,不要昨天,不要明天,只要今天。不一样的你我,不一样的心态,不一样的人生,顺其自然吧
  • 相关阅读:
    USACO Meteor Shower
    小技巧—取模防负
    CSP-S2019 D2T1 Emiya家今天的饭
    重谈DFS序、时间戳和欧拉序
    JDOJ 1842 Magictree
    CSP-S2019 D1T1 格雷码
    洛谷 P3919 【模板】可持久化线段树 1(可持久化数组)
    node+express api编写实战(一):环境安装及启动
    宝塔pureftpd设置FTP后,可连接,但无法上传、新建、覆盖文件的解决方法
    flex布局、css3选择器
  • 原文地址:https://www.cnblogs.com/xiyangchen/p/11108000.html
Copyright © 2020-2023  润新知