算法学习day39-动态规划

打家劫舍

核心思路

  • dp[i][0]: 打劫i 能得到的最大金额

  • dp[i][1]: 不打劫i 能得到的最大金额

  • 推导

    • 打劫i, 能得到的最大金额, 一定是i-1[1] + nums[i]
    • 不打劫i, 能得到的最大金额, 那偷上一家和不偷上一家都可以, 所以要取i-1最大的那个数
    java 复制代码
      public int rob(int[] nums) {
          int[][] dp = new int[nums.length][2];
          //dp[i][0]: 偷i的金额 = [i - 1][1] + nums[i]
          //dp[i][1]: 不偷i的金额 = [i - 1][0]
          dp[0][0] = nums[0];
          dp[0][1] = 0;
          for (int i = 1; i < nums.length; i++) {
              dp[i][0] = dp[i - 1][1] + nums[i];
              dp[i][1] = Math.max(dp[i - 1][0],dp[i - 1][1]);
          }
          return Math.max(dp[nums.length - 1][0],dp[nums.length - 1][1]);
      }

思路2

  • 一维数组

    • 如果打劫i, 那么i的值就是dp[i-2]+nums[i]
    • 如果不打劫i, 那么i的值就等于dp[i-1]
    • 取最大值
    java 复制代码
      public int rob1(int[] nums) {
          if(nums.length == 1){
              return nums[0];
          }
          if(nums.length == 2){
              return Math.max(nums[0],nums[1]);
          }
          int[] dp = new int[nums.length];
          dp[0] = nums[0];
          dp[1] = Math.max(nums[0],nums[1]);
          for (int i = 2; i < nums.length; i++) {
              dp[i] = Math.max(dp[i - 2] + nums[i],dp[i - 1]);
          }
          return dp[nums.length - 1];
      }
相关推荐
☆56610 分钟前
C++中的命令模式
开发语言·c++·算法
仰泳的熊猫12 分钟前
题目2577:蓝桥杯2020年第十一届省赛真题-走方格
数据结构·c++·算法·蓝桥杯
CoovallyAIHub41 分钟前
Pipecat:构建实时语音 AI Agent 的开源编排框架,500ms 级端到端延迟
深度学习·算法·计算机视觉
灰色小旋风1 小时前
力扣13 罗马数字转整数
数据结构·c++·算法·leetcode
2301_810160951 小时前
C++与物联网开发
开发语言·c++·算法
cm6543201 小时前
基于C++的操作系统开发
开发语言·c++·算法
ArturiaZ1 小时前
【day57】
开发语言·c++·算法
CoovallyAIHub1 小时前
Energies | 8版YOLO对8版Transformer实测光伏缺陷检测,RF-DETR-Small综合胜出
深度学习·算法·计算机视觉
Emberone1 小时前
排序:万物皆有序
算法·排序算法
其实秋天的枫1 小时前
2025年12月英语六级真题及答案解析完整版(第一、二、三套全PDF)
经验分享·算法