代码随想录第四十天|打家劫舍 |打家劫舍II |打家劫舍III

ops/2024/9/24 13:20:13/

打家劫舍

这个就和爬楼梯很像,只不过这个每次只能走两步,求最后偷到钱的最大价值。

动规五部曲:

  1. dp[i]代表到下标i的家里时,考虑偷还是不偷的最大价值,这里的考虑非常重要,如果偷下标i的房间,那么dp[i]=dp[i-2]+nums[i]。如果不偷,那就是dp[i]=dp[i-1];因为偷了当前房间,i-1房间就不能偷了。
  2. 所以递推公式:dp[i]=max(dp[i-2]+nums[i],dp[i-1]);
  3. 初始化,dp[0]=nums[0],dp[1]=max(nums[0],nums[1])
  4. 遍历顺序,从前往后
class Solution {public int rob(int[] nums) {if(nums.length==1){return nums[0];}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];}
}

打家劫舍 II

这里数组变成了环形的,首位相连。头节点和尾结点不能同时取。那就进行分类,分成只取头结点时所能偷的最大钱数和只取尾结点时所能偷的最大钱数。

  1. dp[i]表示到下标为i的房间时,考虑偷还是不偷所能得到的最大钱数为dp[i]
  2. 递推公式:dp[i]=max(dp[i-2]+nums[i],dp[i-1]),两种情况的递推公式都是一样的,只是在初始化的时候和遍历的时候有区别
  3. 初始化:只考虑头结点:dp1[0]=nums[0],dp1[1]=max(nums[0],nums[1]);只考虑尾结点:dp2[1]=nums[1],dp2[2]=max(nums[1],nums[2]);
  4. 遍历顺序:只考虑头结点时,从下标0开始遍历到nums.length-2,只考虑尾结点时,从下标1开始遍历到nums.length-1
class Solution {public int rob(int[] nums) {if(nums.length==1){return nums[0];}if(nums.length==2){return Math.max(nums[0],nums[1]);}int[] dp1=new int[nums.length-1];//考虑首元素int[] dp2=new int[nums.length];//考虑尾元素dp1[0]=nums[0];dp2[0]=0;dp1[1]=Math.max(nums[0],nums[1]);dp2[1]=nums[1];dp2[2]=Math.max(nums[1],nums[2]);for(int i=2;i<nums.length-1;i++){dp1[i]=Math.max(dp1[i-2]+nums[i],dp1[i-1]);}for(int i=3;i<nums.length;i++){dp2[i]=Math.max(dp2[i-2]+nums[i],dp2[i-1]);}return Math.max(dp1[nums.length-2],dp2[nums.length-1]);}
}

打家劫舍 III

这是将数组改成了二叉树,这是树形dp的入门题。既然是二叉树,就要考虑使用什么遍历方式,递归和递归三部曲。这里必须使用后序遍历,因为要先将两个孩子上的最大钱数算出来,然后去当前节点偷还是不偷进行比较,如果不偷当前节点,那就偷孩子节点。

动规五部曲:

  1. dp[i]代表到节点i时,偷当前节点的最大钱数为dp[1],不偷当前节点的最大钱数为dp[0]
  2. 递推公式:偷当前节点:val1=cur.val+leftdp[0]+rightdp[0];不偷当前节点:val2=max(leftdp[1],leftdp[0])+max(rightdp[1],rightdp[0]);最终返回值为{不偷当前节点得到的最大金钱,偷当前节点得到的最大金钱}
  3. 初始化:递归不用初始化
  4. 遍历顺序:按照递归

递归三部曲:

  1. 确定参数和返回值:参数就为根节点,返回值为根节点的{不偷当前节点得到的最大金钱,偷当前节点得到的最大金钱}
  2. 终止条件:当遍历到叶子节点后,直接返回{0,0};
  3. 单层处理逻辑:就是偷当前节点和不偷当前节点的最大钱数
class Solution {public int rob(TreeNode root) {int[] dp=robby(root);return Math.max(dp[0],dp[1]);}public int[] robby(TreeNode cur){if(cur==null){return new int[]{0,0};}int[] leftdp=robby(cur.left);int[] rightdp=robby(cur.right);//偷当前节点=当前节点价值+不偷左右子节点int val1=cur.val+leftdp[0]+rightdp[0];//不偷当前节点=左右子节点偷与不偷的最大价值int val2=Math.max(leftdp[0],leftdp[1])+Math.max(rightdp[0],rightdp[1]);return new int[]{val2,val1};}
}


http://www.ppmy.cn/ops/41027.html

相关文章

秒懂k8s中资源的介绍和用法

service介绍 解决什么问题 Pod的生命是有限的&#xff0c;死亡过后不会复活了&#xff0c;尽管每个Pod都有自己的IP地址&#xff0c;但是如果Pod重新启动了的话那么他的IP很有可能也就变化了。这就会带来一个问题&#xff1a;比如我们有一些后端的Pod的集合为集群中的其他前端…

【LLM 论文】Step-Back Prompting:先解决更高层次的问题来提高 LLM 推理能力

论文&#xff1a;Take a Step Back: Evoking Reasoning via Abstraction in Large Language Models ⭐⭐⭐⭐ Google DeepMind, ICLR 2024, arXiv:2310.06117 论文速读 该论文受到的启发是&#xff1a;人类再解决一个包含很多细节的具体问题时&#xff0c;先站在更高的层次上解…

网络层协议之 IP 协议

IP 协议格式 4 位版本&#xff1a;此处的取值只有两个&#xff0c;4&#xff08;IPv4&#xff09;和 6&#xff08;IPv6&#xff09;&#xff0c;即指定 IP 协议的版本。 4 位首部长度&#xff1a;描述了 IP 报头多长&#xff0c;IP 报头是变长的&#xff0c;因为报头中的选项部…

【simulink】Scrambling 加扰

https://ww2.mathworks.cn/help/comm/ug/additive-scrambling-of-input-data-in-simulink.html 草图 simulink 代码图

蓝桥杯-移动距离(最简单的写法)

X星球居民小区的楼房全是一样的&#xff0c;并且按矩阵样式排列。 其楼房的编号为 1,2,3…当排满一行时&#xff0c;从下一行相邻的楼往反方向排号。 比如&#xff1a;当小区排号宽度为 6 时&#xff0c;开始情形如下&#xff1a; 1 2 3 4 5 6 12 11 10 9 8 7 13 14 15 … 我…

攻防世界(CTF)~web-supersqli(详细解题思路)

题目介绍 题目描述“随便注” 先看一下是否存在注入 判断闭合方式 输入1’ and 11-- -正常回显 输入1and 12-- -无回显,确认是单引号闭合 看一下列数 输入1 order by 2-- - 有回显 输入1 order by 3-- - 报错&#xff0c;由此判断两列 使用union联合注入发现select被过滤了&a…

echarts legend图例颜色不统一问题

项目里发现这种图片,线和圈圈颜色不统一 查看代码后发现,设置了公共的color, 并且只作用在了series里, 并没有作用在option全局里, 所以需要在option里添加color. const chartObj {colors:[#49B3FF, #26C89A]}option {//echarts里的optioncolor: chartObj.colors,} 这样即可…

Photoshop中绘图及图像修饰工具的应用

Photoshop中绘图及图像修饰工具的应用 Photoshop中的颜色设置与取样前景色与背景色颜色取样 Photoshop中的颜色替换工具Photoshop中的渐变工具Photoshop中的描边命令Photoshop中的填充工具采用油漆桶进行填充采用填充命令进行填充 Photoshop中的擦除工具 Photoshop中的颜色设置…