代码随想录Day52 | 打家劫舍

代码随想录Day52 | 打家劫舍

  • 198.打家劫舍
  • 213.打家劫舍II
  • 337.打家劫舍III

198.打家劫舍

文档讲解:代码随想录
视频讲解: 动态规划,偷不偷这个房间呢?| LeetCode:198.打家劫舍
状态

选与不选

  1. dp数组
    dp[j] 表示第j个位置的最大金额
  2. 递推公式
    dp[j] 是由dp[j-1]和dp[j-2]决定的,如果偷了j-1的房间就不能偷j,所以此时的金额是dp[j-1],如果没有偷j-1,那么dp[j]就是dp[j-2]+nums[j],所以取两者最大值即可
  3. 初始化
    要单独考虑没有房子或者房子只有有一个的情况
if(nums.size()==0) return 0;
if(nums.size() == 1) return nums[0];
dp[0] = nums[0];
dp[1] = max(nums[0],nums[1]);
  1. 遍历顺序
    从前向后即可
  2. 打印dp
//不能偷取相邻的
//dp[j] 表示第j个位置能获取到的最大金额
class Solution {
public:int rob(vector<int>& nums) {if(nums.size() == 0) return 0;if(nums.size() == 1) return nums[0];vector<int> dp(nums.size(),0);dp[0] = nums[0];dp[1] = max(nums[0],nums[1]);for(int i = 2;i<nums.size();i++){dp[i] = max(dp[i-1],dp[i-2]+nums[i]);}return dp[nums.size()-1];}
};

213.打家劫舍II

文档讲解:代码随想录
视频讲解: 动态规划,房间连成环了那还偷不偷呢?| LeetCode:213.打家劫舍II
状态

首尾相连,导致第一个元素和最后一个元素相邻,原本有3种情况

不包含首尾
不包含尾
不包含首

第二种和第三种情况包含了第一种所以可以不用考虑,但需要注意的是,包含首或者尾,并不代表要选择首或者尾

所以我们可以对两种情况分别求取最大值,然后再求一个最大值就可以了。

class Solution {
public:int findMax(vector<int>& nums){if(nums.size() == 0) return 0;if(nums.size() == 1) return nums[0];vector<int> dp(nums.size(),0);dp[0] = nums[0];dp[1] = max(nums[0],nums[1]);for(int i = 2;i<nums.size();i++){dp[i] = max(dp[i-1],dp[i-2]+nums[i]);}return dp[nums.size()-1];}
public:int rob(vector<int>& nums) {if(nums.size() == 0) return 0;if(nums.size() == 1) return nums[0];vector<int> left(nums.begin(),nums.end()-1);vector<int> right(nums.begin()+1,nums.end());return(max(findMax(left),findMax(right)));}
};

337.打家劫舍III

文档讲解:代码随想录
视频讲解:

状态

父子节点不能同时偷取。

树形dp利用遍历二叉树确定递推公式
对于二叉树的遍历,有前后中以及层序遍历,这道题需要选择后序遍历,因为我们需要通过每层的返回值来判断中节点是否偷取,然后计算最终的偷取最大金额。

记忆化递归,利用数据结构记录已经递归过的结果,然后后续遇到就直接使用。

  1. dp数组
    因为是递归过程,dp数组只需要保存当前层的结果,即是否选择当前节点,那么就是一个2个元素的数组,分别表示选择或者不选择的偷取金额
  2. 递推公式
    相当于对于中节点的操作,如果偷取了中节点,那么左孩子和右孩子就不能偷 cur+left[0]+right[0]
    如果没有偷取中节点,那么左右孩子都可以偷,但是否偷就是选择最大的max(left[0],left[1]) + max(right[0],right[1])
    mid = {max(left[0],left[1]) + max(right[0],right[1]) , cur+left[0]+right[0] };
  3. 初始化
    相当于是递归到最后一层,初始化为0,0
  4. 遍历顺序
    对于左节点,计算是否偷取的结果金额
    对于右节点,计算是否偷取的结果金额
  5. 打印dp
/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:vector<int> FindRob(TreeNode* root){if(root == nullptr) return vector<int>{0,0};//遍历左右节点vector<int> left = FindRob(root->left);vector<int> right = FindRob(root->right);int val1 = root->val+left[0]+right[0];int val2 = max(left[0],left[1])+max(right[0],right[1]);return vector<int>{val2,val1};}
public:int rob(TreeNode* root) {vector<int> res = FindRob(root);return max(res[0],res[1]);}
};

树形dp的解决
将dp数组的初始化变为终止条件
dp数组的遍历变为递归顺序
dp数组的递推公式变为单层逻辑的处理

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

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

相关文章

【医学知识图谱 自动补全 关系抽取】生成模型 + 医学知识图谱 = 发现三元组隐藏的关系实体对

生成模型 医学知识图谱 发现三元组新关系实体对 提出背景问题&#xff1a;如何自动发现并生成医疗领域中未被标注的实体关系三元组&#xff1f;CRVAE模型 提出背景 论文&#xff1a;https://dl.acm.org/doi/pdf/10.1145/3219819.3220010 以条件关系变分自编码器&#xff08;…

第7章 Page449 7.8.9智能指针 std::unique_ptr课堂作业,使用智能指针改写foo()函数

源代码&#xff1a; /** \brief 使用std::unique_ptr改写智能指针章节开始的foo()函数** \param* \param* \return**/ #include <iostream> #include <memory>using namespace std;struct O {~O(){cout << "我是被管的对象。我要被释放啦......" …

php基础学习之文件包含

描述 在一个php脚本中&#xff0c;将另一个php文件包含进来&#xff0c;合作实现某种功能 这个描述看起来似乎和C/Java等语言的头文件/包有点类似&#xff0c;但本质是不一样的 打个比方&#xff1a; C/Java的头文件/包更像是一个工具箱&#xff0c;存放各种很完善的工具&#…

Git快速掌握,通俗易懂

Git分布式版本控制工具 介绍 Git是一个开源的分布式版本控制系统&#xff0c;用于敏捷高效地处理任何或小或大的项目。Git是由Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。Git可以帮助开发者们管理代码的版本&#xff0c;避免代码冲突&#…

C# 异步方法的使用场景

我一直认为C#的异步方法只是一堆华而不实的东西&#xff0c;坑特别多&#xff0c;比起直接自建线程也没有任何优势。 直到有一天&#xff0c;一个需求场景&#xff0c;让我再次想到了C#的异步方法。 需求场景如下&#xff1a;需要写一个程序控制机械臂完成各种动作。每个动作要…

机器学习分类评估四个术语TP,FP,FN,TN

分类评估方法主要功能是用来评估分类算法的好坏&#xff0c;而评估一个分类器算法的好坏又包括许多项指标。了解各种评估方法&#xff0c;在实际应用中选择正确的评估方法是十分重要的。 这里首先介绍几个常见的模型评价术语&#xff0c;现在假设我们的分类目标只有两类&#x…

Dockerfile 常用指令

1、FROM 指定base镜像。 2、Docker history 显示镜像的构建历史&#xff0c;也就是Dockerfile的执行过程。 Missing 表示无法获取IMAGE ID&#xff0c;通常从Docker Hub下载的镜像会有这个问题。 3、调试Dockerfile&#xff0c;使用sudo docker run -it XXXX&#xff0c;XXXX…

英文单词-计算:Calculate与Compute的区别是什么

英文单词-计算:Calculate与Compute的区别是什么 compute 源自法语&#xff1b;calculate 源自拉丁语。在使用上&#xff0c;calculate 使用得更为广泛 calculate侧重人的分析&#xff0c;而compute侧重机器的运算。 calculator是“计算器”&#xff0c;而computer是“计算机”…

【大数据面试题】007 谈一谈 Flink 背压

一步一个脚印&#xff0c;一天一道面试题&#xff08;有些难点的面试题不一定每天都能发&#xff0c;但每天都会写&#xff09; 什么是背压 Backpressure 在流式处理框架中&#xff0c;如果下游的处理速度&#xff0c;比上游的输入数据小&#xff0c;就会导致程序处理慢&…

输入输出自定义映射矩阵(数据结构树)

输出自定义FC其它算法实现&#xff0c;可以参考下面文章&#xff1a; https://rxxw-control.blog.csdn.net/article/details/125994252https://rxxw-control.blog.csdn.net/article/details/125994252下面我们看下我们的控制要求。在学习本篇博客之前大家可以熟悉下数据结构图…

Mybatis——Javaweb进阶学习(五)

目录 一、Mybatis快速入门1.创建Springboot工程&#xff0c;数据库表user&#xff0c;实体类User2.引入Mybaties相关依赖3.编写Sql语句 二、lombok1.基本概念2.使用方法 三、基础操作1.环境准备a.数据库准备b.创建员工实体类Emp数据类型对比命名对比 c.Mapper接口创建 2.删除操…

CSS盒子的概念

盒子模型 盒子的概念 页面中的每一个标签都可以看做是一个“盒子”&#xff0c;通过盒子的视角更方便的进行布局 浏览器在渲染&#xff08;显示&#xff09;网页时&#xff0c;会将网页中的元素看做是一个个的矩形区域&#xff0c;称之为“盒子” 盒子模型 CSS中规定每个盒…

从计算机恢复已删除文件的 6 种方法!

如果您的重要文件之一已从计算机中删除怎么办&#xff1f;如果不小心从硬盘中删除了文件怎么办&#xff1f; 如今的公司通常将重要数据存储在云或硬盘中。但最重要的是&#xff0c;您必须考虑这样一个事实&#xff1a;您可能会丢失计算机上的数据。数据丢失的原因有多种&#x…

C语言-----用二维数组解决菱形的打印问题

1.打印菱形&#xff0c;多组输入&#xff0c;一个整数&#xff08;2~20&#xff09;&#xff0c;表示输出的行数&#xff0c;也表示组成“X”的反斜线和正斜线的长度。 #include <stdio.h>int main() {int n0;while(scanf("%d",&n)! EOF){int i0;int j0;f…

python第六节:字典dict(2)

修改字典 1 直接给字典中不存在的键赋值 例子1&#xff1a; dict1 {name: 张三, age: 18, sex: 女,0: 0}print(dict1) dict1[new1]new_value1dict1[3]new_value3print(dict1) 结果1&#xff1a; {name: 张三, age: 18, sex: 女, 0: 0} {name: 张三, age: 18, sex: 女, 0…

Python爬虫html网址实战笔记

仅供学习参考 一、获取文本和链接 import requests from lxml import htmlbase_url "https://abcdef自己的网址要改" response requests.get(base_url) response.encoding utf-8 # 指定正确的编码方式tree html.fromstring(response.content, parserhtml.HTML…

【数据结构】12 堆栈应用:表达式求值

表达式类型 后缀表达式 有一个常量表达式的中缀表达式为&#xff1a;5 6 / 2 - 3 * 4&#xff0c;其后缀形式表示为&#xff1a; 5 6 2 / 3 4 -。后缀表达式的特点是运算符位于两个预算数之后。其前缀表达式为&#xff1a; - 5 / 6 2 3 4。 后缀表达式相比于中缀表达式的…

彻底理解无刷电机

前言 现在很多设备都是搭载的无刷电机而不是有刷电机了&#xff0c;为啥&#xff1f;性能好啊&#xff01; 引入 同性相斥异性相吸 可以看出&#xff0c;只要改变磁铁的极性&#xff0c;电机就能转起来 那 怎么改变磁铁极性呢&#xff1f; 右手螺旋定则可以根据电流的流向…

LeeCode 546 区间 DP

题意 传送门 LeeCode 546 移除盒子 题解 难以顺序处理&#xff0c;故考虑不断拓展区间。令 d p l , r dp_{l, r} dpl,r​ 为 [ l , r ) [l,r) [l,r) 的答案&#xff0c;当 b l b_{l} bl​ 与 b r − 1 b_{r-1} br−1​ 不在同一轮被移除&#xff0c;则可以枚举分界点更新…

可变参数(c/c++)

目录 一、C语言版本 二、C的实现方法 2.1数据包 2.2sizeof...运算符 2.3可变参数模板的使用 2.4emplace_back() 有时候我们在编写函数时&#xff0c;可能不知道要传入的参数个数&#xff0c;类型 。比如我们要实现一个叠加函数&#xff0c;再比如c语言中的printf,c中的emp…