LeetCode 打卡day48--打家劫舍I, II, III

一个人的朝圣 — LeetCode打卡第48天

  • 知识总结
  • Leetcode 198. 打家劫舍
    • 题目说明
    • 代码说明
  • Leetcode 213. 打家劫舍 II
    • 题目说明
    • 代码说明
  • Leetcode 337. 打家劫舍 III
    • 题目说明
    • 代码说明


知识总结

今天全是打家劫舍系列的题目, 还挺有意思的


Leetcode 198. 打家劫舍

题目链接

题目说明

你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。

给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。
在这里插入图片描述

代码说明

重点在于递推公式的理解和dp数组的意义.

  1. dp数组表示考虑当前屋子的最大收益, 并不代表着一定会偷当前的屋子
  2. 递推公式为

dp[i] = Math.max(dp[i-2] + nums[i], dp[i-1])

class Solution {public int rob(int[] nums) {int len = nums.length;int[] dp = new int[len];if(len == 1) return nums[0];dp[0] = nums[0];dp[1] = Math.max(nums[0], nums[1]);if(len == 2) return dp[1];for(int i = 2; i < len; i++){dp[i] = Math.max(dp[i-2] + nums[i], dp[i-1]);}return dp[len-1];}

Leetcode 213. 打家劫舍 II

题目链接

题目说明

你是一个专业的小偷,计划偷窃沿街的房屋,每间房内都藏有一定的现金。这个地方所有的房屋都 围成一圈 ,这意味着第一个房屋和最后一个房屋是紧挨着的。同时,相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警 。

给定一个代表每个房屋存放金额的非负整数数组,计算你 在不触动警报装置的情况下 ,今晚能够偷窃到的最高金额。
在这里插入图片描述

代码说明

环要如何处理, 其实可以分类讨论, 一种是取首不取尾, 另外一种是取尾不取首. 然后再取两种结果的最大值即可.
要注意这边我们传递的时候, 将start, end传进去

class Solution {public int rob(int[] nums) {int len = nums.length;if(len == 1) return nums[0];if(len == 2) return Math.max(nums[0], nums[1]);return Math.max(robAction(nums, 0, len-2), robAction(nums, 1, len-1));}public int robAction(int[] nums, int start, int end){int len = end - start + 1;int[] dp = new int[len+1];if(len == 1) return nums[start];dp[0] = nums[start];dp[1] = Math.max(nums[start], nums[start+1]);if(len == 2) return dp[1];for(int i = start+2; i <=end; i++){dp[i-start] = Math.max(dp[i-start-2] + nums[i], dp[i-start-1]);}// System.out.println(Arrays.toString(dp));return dp[end-start];}
}

Leetcode 337. 打家劫舍 III

题目链接

题目说明

小偷又发现了一个新的可行窃的地区。这个地区只有一个入口,我们称之为 root 。

除了 root 之外,每栋房子有且只有一个“父“房子与之相连。一番侦察之后,聪明的小偷意识到“这个地方的所有房屋的排列类似于一棵二叉树”。 如果 两个直接相连的房子在同一天晚上被打劫 ,房屋将自动报警。

给定二叉树的 root 。返回 在不触动警报的情况下 ,小偷能够盗取的最高金额 。

代码说明

需要后序的遍历这个数, 每一个节点有一个单独的dps数组, dp[0]表示偷该节点的最大收益, dp[1]表示不偷的最大收益

class Solution {public int rob(TreeNode root) {int[] dpCur = dfs(root);return Math.max(dpCur[0], dpCur[1]);}public int[] dfs(TreeNode root){if(root == null) return new int[2];int[] dpLeft = dfs(root.left);int[] dpRight = dfs(root.right);int[] dpCur = new int[2];// dpCur[0] steal cur nodedpCur[0] = root.val + dpLeft[1] + dpRight[1];// dpCur[1] does not steal cur node;dpCur[1] = Math.max(dpLeft[0], dpLeft[1]) + Math.max(dpRight[0], dpRight[1]);return dpCur;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/5292.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C++初阶(二)】缺省参数以及函数重载

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:C初阶之路⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学习排序知识   &#x1f51d;&#x1f51d; 缺省参数&#xff06;函数重载 1. 前言2. 缺…

python学习——函数

一、函数的定义 函数就是执行特定任务和完成特定功能的一段代码。使用函数可以对代码进行复用&#xff0c;提高代码的可维护性和可读性&#xff0c;使得程序便于调试。 二、函数的创建 创建格式 #创建和格式 def 函数名&#xff08;[参数]&#xff09;:函数体[return xxx]举例…

MySQL:库的操作和表的操作(内含MySQL数据类型讲解)

进入数据库的数据目录 cd var/lib/mysql 库的操作 创建数据库 创建数据库的本质是创建目录。 创建数据库时有两个编码集&#xff1a;1.数据库编码集&#xff08;存储时使用&#xff09;2.进行字段比对读取时使用的编码方式&#xff09; 语法&#xff1a; CREATE DATABASE …

7、Redis复制(replica)

Redis复制(replica) 是什么&#xff1f; 就是主从复制&#xff0c;master以写为主&#xff0c;Slave以读为主。当master数据变化的时候&#xff0c;自动将新的数据异步同步到其它slave数据库 读写分离 容灾恢复 数据备份 水平扩容支撑高并发 案例演示 架构说明 一个Master两个…

微服务系列文章之 seata 事务模式

XA模式 XA 规范 是 X/Open 组织定义的分布式事务处理&#xff08;DTP&#xff0c;Distributed Transaction Processing&#xff09;标准。 XA 规范 描述了全局的TM与局部的RM之间的接口&#xff0c;几乎所有主流的数据库都对 XA 规范 提供了支持。 两阶段提交 XA是规范&…

深度学习优化算法

梯度下降算法 随机梯度下降。随机梯度下降是指每次迭代在训练数据中随机抽取一个数据计算梯度来更新模型得参数。随机梯度下降容易受到噪声干扰,训练时间长,代价函数最终会围绕全局最小值或者局部极小值震荡。批量梯度下降。每次迭代时使用所有的训练数据来计算梯度更新模型的…

UE5 录制透明png序列帧

以下是在 Unreal Engine 5 中录制透明 PNG 序列帧的详细步骤&#xff1a; 步骤1&#xff1a;创建一个场景 步骤2&#xff1a;打开序列录制器 在 Unreal Engine 5 中&#xff0c;首先需要打开序列录制器。你可以通过点击顶部菜单栏的 窗口 > 开发人员工具 > 序列录制器 …

WEB漏洞-XXEXML之利用检测绕过全解(39)

#概念 xml&#xff1a;xml被设计成传输和储存数据&#xff0c;XML文档结构包括XML声明、DTD文档类型定义(可选)、文档元素&#xff0c;其焦点是数据的内容。就类似于一种数据的格式&#xff0c;代码类的一些东西&#xff1b; xxe&#xff1a;是xml上面的一个漏洞&#xff0c;…

mesh网格数据解析及cesium绘制格网三角网可视化实现

代码实现运行效果 技术术语 Mesh通常指网络拓扑中的网状结构。在计算机网络中&#xff0c;Mesh是指每个节点都与其他节点相连&#xff0c;形成一个无中心的网状结构。Mesh网络常见于分布式计算、传感器网络、互联网等场景中。另外&#xff0c;在3D计算机图形学中&#xff0c;M…

MATLAB 之 Simulink 系统仿真实例和 S 函数的设计与应用

这里写目录标题 一、Simulink 系统仿真实例1. 方法一2. 方法二3. 方法三 二、S 函数的设计与应用1. 用 MATLAB 语言编写 S 函数1.1 主程序1.2 子程序 2. S 函数的应用 一、Simulink 系统仿真实例 下面的应用实例我们将分别采用不同建模方法为系统建模并仿真。例如&#xff0c;…

【AUTOSAR】BMS开发实际项目讲解(三十一)----电池管理系统电池热管理功能

电池热管理功能 关联的系统需求 Sys_Req_4101、Sys_Req_4102、Sys_Req_4103、Sys_Req_4104、Sys_Req_4105; 功能实现描述 为保证电池系统的热安全&#xff0c;以及电池系统不同温度环境下的工作性能&#xff0c;本车型具备热管理功能。 表-热管理功能配置 功能 功能描述 …

vim多文件切换快捷键设置

1、基本切换指令 vim中在打开多个文件时&#xff0c;会有多个文件进行切换的需求。按:bn切换到下一个文件&#xff0c;按:bp切换到上一个文件。 2、快捷键设置 为了便捷操作&#xff0c;将切换命令设置成快捷键。 进入/home/yys个人目录下&#xff0c;vim .vimrc进入vimrc文…