代码随想录训练营Day 45|力扣1049. 最后一块石头的重量 II、494. 目标和、474.一和零

1.最后一块石头的重量2

视频讲解:动态规划之背包问题,这个背包最多能装多少?LeetCode:1049.最后一块石头的重量II_哔哩哔哩_bilibili

代码随想录

代码:

class Solution {
public:int lastStoneWeightII(vector<int>& stones) {int sum = 0;for(int i = 0;i < stones.size(); i++){sum += stones[i];}int begweight = sum / 2;// 初始化dp数组vector<int> dp(begweight + 1,0);// 递推公式for(int i = 0; i < stones.size(); i++){for(int j = begweight; j >= stones[i]; j--){dp[j] = max(dp[j],dp[j - stones[i]] + stones[i]);}}int result = sum - dp[begweight] - dp[begweight];return result;}
};

 思路:这道题和划分等和子集的题的思路很像,我们尽量把石头按照重量等分成两组,然后碰撞,这样剩下的石头重量最低。这道题也是把石头的重量看成是它的价值。

dp数组的含义:dp[j]表示 用物品1-i去装容量为j的背包所得的最大重量

dp数组的递推公式:就是一维滚动01背包的基础上,把价值换成了重量。 dp[j] = max(dp[j],dp[j - stones[i]] + stones[i])

dp数组的初始化:为了为了确保每个物品只被添加一次,我们在遍历物品的循环中使用了倒序遍历。这是因为如果在正序遍历的情况下,当我们计算 dp[j] 时,dp[j-weight[i]] 已经被更新过了,如果当前物品被多次添加,则 dp[j] 的值会受到影响,不再是我们期望的状态。

这道题我又错了,sos!!在写j的for循环的时候,把j的边界条件写错了,j >= stones[i]!!!!!

2.目标和

视频讲解:动态规划之背包问题,装满背包有多少种方法?| LeetCode:494.目标和_哔哩哔哩_bilibili

代码随想录

代码: 

class Solution {
public:int findTargetSumWays(vector<int>& nums, int target) {// 可以把数组分成left和right两个阵营。left是正数组。right是负数组。// 这样left+right=target left-right=sum// left=(target + sum)/2 只要去求用nums里的物品有多少种方法装满容量为left的背包就好了int sum = 0;for(int i = 0; i < nums.size(); i++){sum += nums[i];}if (abs(target) > sum) return 0; if((sum + target) % 2 == 1){ // 如果left都不是整数,说明没有求得target的表达式return 0;}int left = (sum + target)/2;// 定义和初始化dp数组vector<int> dp(left + 1,0);dp[0] = 1;// 递推公式for(int i = 0; i < nums.size(); i++){for(int j = left; j >= nums[i]; j--){dp[j] += dp[j - nums[i]]; // 可以看作是求什么情况下,再添一个元素就正好到容量j了(就像爬楼梯一样,只不过这道题没有限制只能爬一层台阶,所以我们出发的起点就很多}}return dp[left];}
};

 思路:

        这道题其实可以把数组分成left和right两个阵营。left是正数组。right是负数组。这样left+right=target left-right=sum推出left=(target + sum)/2。——>只要去求用nums里的物品有多少种方法装满容量为left的背包就好了。

        涉及到求方法类的问题,可以看作是求什么情况下,再添一个元素就正好到容量j了(就像爬楼梯一样,只不过这道题没有限制只能爬一层台阶,所以我们出发的起点就很多。也可以求用我们之前做过的路径总和来类比。

dp数组的含义:dp[j] 用物品0~i装满容量为j的背包有多少种方法

dp数组的递推公式:dp[j] += dp[j - nums[i] ]

dp数组的初始化:

        从递推公式可以看出,在初始化的时候dp[0] 一定要初始化为1,因为dp[0]是在公式中一切递推结果的起源,如果dp[0]是0的话,递推结果将都是0。

        这里有录友可能认为从dp数组定义来说 dp[0] 应该是0,也有录友认为dp[0]应该是1。

        其实不要硬去解释它的含义,咱就把 dp[0]的情况带入本题看看应该等于多少。

        如果数组[0] ,target = 0,那么 bagSize = (target + sum) / 2 = 0。 dp[0]也应该是1, 也就是说给数组里的元素 0 前面无论放加法还是减法,都是 1 种方法。

        所以本题我们应该初始化 dp[0] 为 1。

        可能有同学想了,那 如果是 数组[0,0,0,0,0] target = 0 呢。

        其实 此时最终的dp[0] = 32,也就是这五个零 子集的所有组合情况,但此dp[0]非彼dp[0],dp[0]能算出32,其基础是因为dp[0] = 1 累加起来的。

对了,这道题我一开始提交的时候显示我溢出了,后来加上了 if (abs(target) > sum) return 0;这句话就过了。

3.一和零

视频讲解:动态规划之背包问题,装满这个背包最多用多少个物品?| LeetCode:474.一和零_哔哩哔哩_bilibili

代码随想录

代码:

class Solution {
public:int findMaxForm(vector<string>& strs, int m, int n) {// 定义dp数组 这道题相当于从两个维度装背包,因此定义一个二维的dp数组vector<vector<int>> dp(m + 1,vector<int>(n + 1,0));// 递推公式for(string str : strs){ // 遍历物品int oneNum = 0;int zeroNum = 0;for(char c : str){ if(c == '0'){ // 统计每个物品里0、1的数量zeroNum++;}else{oneNum++;}}for(int j = m; j >= zeroNum; j--){for(int k = n; k >= oneNum; k--){dp[j][k] = max(dp[j][k],dp[j - zeroNum][k - oneNum] + 1);// 因为我们求的是装满容量为j,k的最多的物品数量,所以这里的value换成了数量1}}}return dp[m][n];}
};

 思路:

这道题相当于从两个维度(专门装0,和专门装1的背包容量)装背包,问装满背包的最多的物品数量为多少

dp数组的含义:dp[j][k]装满(专门装0容量为j,和专门装1容量为k)的背包,最多所用的物品数量

dp数组的递推公式:dp[j][k] = max(dp[j][k],dp[j - zeroNum][k - oneNum] + 1)

dp数组的初始化:为了不影响我们取最大值,全部初始化为0

dp数组的遍历顺序:就和滚动数组的一样,为了每个物品只被添加一次,倒叙遍历

这道题,我又又又错了,那个j和k的for循环和统计一个元素中的01个数的循环 是并列关系,我写成嵌套了[悲伤]

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

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

相关文章

芋道系统,springboot+vue3+mysql实现地址的存储与显示

1.效果图 2.前端实现&#xff1a; <el-form-item label"地址" prop"entrepriseAddress"><el-cascaderv-model"formData.entrepriseAddress"size"large":options"region"/></el-form-item> //导入组件 im…

k8s中pod如何排错?

排除Kubernetes Pod故障通常涉及一系列步骤&#xff0c;以诊断问题并找到解决方案。以下是一些常见的故障排除方法&#xff1a; 检查Pod状态: 使用kubectl get pods查看Pod的状态。如果Pod没有处于Running状态&#xff0c;查看更详细的信息&#xff0c;使用kubectl describe …

【JMeter接口自动化】第7讲 Jmeter三个重要组件

线程组:是JMeter中最基本的元素之一&#xff0c;用于模拟并发用户访问目标系统。线程组定义了测试计划中的用户数量、用户行为和用户请求之间的关系。 添加方法:测试计划->添加->线程(用户)->线程组 在线程组中&#xff0c;您可以设置以下参数&#xff1a; 线程数&a…

一种改进的形态学滤波算法-以心电信号的基线校正和噪声抑制为例(MATLAB环境)

信号在釆集和传输过程中难免受到噪声源的干扰&#xff0c;反映非线性动力学行为的特征信息有可能被噪声所掩盖。尤其是在混沌振动信号噪声抑制方面&#xff0c;因为混沌信号的高度非线性及宽频特性&#xff0c;噪声和混沌信号往往具有重叠的带宽。传统的时域及频域降噪方法效果…

高通Android 12/Android 13截屏

正常截屏Power音量-键 组合键同时长按&#xff0c;实现截屏逻辑。 PhoneWindowManager #init #interceptScreenshotChord init(Context context, IWindowManager windowManager,WindowManagerFuncs windowManagerFuncs) 2、在PhoneWindowManager中init方法中注册广播 framew…

神经网络-------人工神经网络

一、什么是神经网络和神经元 人工神经网络&#xff08;英语&#xff1a;Artificial Neural Network&#xff0c;ANN&#xff09;&#xff0c;简称 神经网络&#xff08;Neural Network&#xff0c;NN&#xff09;或 类神经网络&#xff0c;是一种模仿生物神经网络&#xff08;…

AI实时免费在线图片工具3:人物换脸、图像编辑

1、FaceAdapter 人物换脸 https://huggingface.co/spaces/FaceAdapter/FaceAdapter 2、InstaDrag https://github.com/magic-research/InstaDrag

cnc编程与nc编程的区别:深入解析两者之间的核心差异

cnc编程与nc编程的区别&#xff1a;深入解析两者之间的核心差异 在制造业中&#xff0c;编程技术是实现高精度、高效率加工的关键环节。CNC编程和NC编程作为两种重要的编程方式&#xff0c;各自具有独特的特点和应用场景。然而&#xff0c;对于初学者或非专业人士来说&#xf…

计算机网络之快重传和快恢复以及TCP连接与释放的握手

快重传和快恢复 快重传可以让发送方尽早得知丢失消息&#xff0c; 当发送消息M1,M2&#xff0c;M3,M4,M5后,假如消息M2丢失&#xff0c;那么按照算法会发送对M2报文前一个报文M1的重复确认&#xff08;M1正常接受到&#xff0c;已经发送了确认),然后之后收到M4,M5,也会发送两…

做项目时,怎么运用 SWOT 分析法进行项目或决策分析?

SWOT分析法是一种常用的战略工具&#xff0c;用于评估项目或决策的优势、劣势、机会和威胁。以下是在项目或决策分析中如何运用SWOT分析法的一般步骤&#xff1a; 步骤1&#xff1a;明确分析的目标 在进行SWOT分析之前&#xff0c;首先要明确分析的目标是什么。你可能想要分析…

element-plus关于表单数据自定义参数校验

element-plus关于表单数据自定义参数校验 核心点&#xff1a; 代码&#xff1a; <el-form-item :prop"tableData[ scope.$index ].score":rules"[{ required: true, message: 得分不能为空, trigger: blur },{ validator: (rule: any, value: any, ca…

【Python】解决Python报错:AttributeError: ‘generator‘ object has no attribute ‘xxx‘

&#x1f9d1; 博主简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟&#xff0c;欢迎关注。提供嵌入式方向…

网络分层与各层网络协议介绍

一.OSI七层模型 1.OSI&#xff08;Open Systems Interconnection&#xff09;七层模型是由国际标准化组织&#xff08;ISO&#xff09;提出的一种网络通信协议的参考模型&#xff0c;用于标准化网络通信的过程。 OSI模型将网络通信分为七个层次&#xff0c;每个层次负责不同的…

Java集合-List(Collection子接口)及其子类(ArrayList、Vector、LinkedList)

List接口是 Collection接口的子接口。 1、List集合类中数据有序&#xff0c; 即添加顺序和取出顺序有序&#xff0c;而且可以重复。 2、List集合类中每个元素都有其对应的顺序索引&#xff0c;即支持索引。例&#xff0c;list.get(2)&#xff1b;取第三个元素。 3、实现类有很多…

cocosCreator2.x滑动组件全面版一体化(虚拟列表+分页列表+普通列表改良版)

/******************************************* author kL <klk0qq.com>* date 2019/6/6* doc 列表组件.* end******************************************/ /* eslint-disable */ const { ccclass, property, disallowMultiple, menu, executionOrder, requireComponent…

家政预约小程序10公众号集成

目录 1 使用测试号3 工作流配置4 配置关注事件脚本5 注册开放平台6 获取公众号access_token6 实现关注业务逻辑总结 我们本次实战项目构建的相当于一个预约平台&#xff0c;既有家政企业&#xff0c;也有家政服务人员还有用户。不同的人员需要收到不同的消息&#xff0c;比如用…

99.网络游戏逆向分析与漏洞攻防-ui界面的设计-角色信息显示的界面与功能

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 如果看不懂、不知道现在做的什么&#xff0c;那就跟着做完看效果&#xff0c;代码看不懂是正常的&#xff0c;只要会抄就行&#xff0c;抄着抄着就能懂了 内容…

机器人学导论P115求雅可比矩阵python实现

代码如下&#xff1a; import numpy as np import matplotlib.pyplot as plt import seaborn as sns import plotly.express as px import plotly.graph_objects as go from plotly.subplots import make_subplots from numpy import sin from numpy import cos plt.rcParams[…

【考试100】安全员B证《建设工程安全生产技术》单选题

​ 题库来源&#xff1a;考试100 【考试100】安全员B证《建设工程安全生产技术》单选题 1&#xff0e;在悬空部位作业时&#xff0c;操作人员应&#xff08; &#xff09; A.遵守操作规定 B.进行安全技术交底 C.戴好安全帽 D.系好安全带 【考试100答案】&#xff1a;D…

【R基础】如何开始学习R-从下载R及Rstudio开始

文章目录 概要下载R流程下载Rstudio流程下载完成-打开 概要 提示&#xff1a;如何开始学习R-从下载R及Rstudio开始&#xff0c;此处我只是想下载指定版本R4.3.3 下载R流程 链接: R官网 文件下载到本地 下载文件展示 按照向导指示安装 下载Rstudio流程 链接: Rstudio官网…