zoukankan      html  css  js  c++  java
  • 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 }
    无论有多困难,都坚强的抬头挺胸,人生是一场醒悟,不要昨天,不要明天,只要今天。不一样的你我,不一样的心态,不一样的人生,顺其自然吧
  • 相关阅读:
    性能02篇-性能测试工具介绍
    网关协议:CGI和WSGI
    Spring Cloud与微服务构建:Spring Cloud简介
    前端基础:HTTP 状态码详解
    Spring Cloud与微服务构建:微服务简介
    Redis 基础:Redis 事件处理
    Redis 基础:Redis 数据类型
    Redis 基础:Redis 配置
    Django 2.0 学习(22):Django CSRF
    Django 2.0 学习(21):Django Session
  • 原文地址:https://www.cnblogs.com/xiyangchen/p/11108000.html
Copyright © 2011-2022 走看看