【代码随想录】【算法训练营】【第42天】 [1049]最后一块石头的重量II [494]目标和 [474]一和零

前言

思路及算法思维,指路 代码随想录。
题目来自 LeetCode。

day 42,周二,坚持一下~

题目详情

[1049] 最后一块石头的重量II

题目描述

1049 最后一块石头的重量II
1049 最后一块石头的重量II

解题思路

前提:最多只会剩下一块 石头,求此石头最小的可能重量
思路:将原数组分为两个子集,使其重量和最相近,此时剩余重量最小。0-1背包问题,动态规划。
重点:问题转化为0-1背包问题,dp数组的定义、初始化及推导公式。

代码实现

C语言
dp[i][j]

分为两个子集,使其重量和最相近,此时剩余重量最小
dp[i][j]: 在[0, i]中, 不大于重量j的石头重量和
dp[i][j] = max(dp[i-1][j], dp[i-1][j-stones[i]]+stones[i])

int sumFun(int *stones, int stonesSize)
{int sum = 0;for (int i = 0; i < stonesSize; i++) {sum += stones[i];}return sum;
}int maxFun(int p1, int p2)
{return p1 > p2 ? p1 : p2;
}int lastStoneWeightII(int* stones, int stonesSize) {int totalSum = sumFun(stones, stonesSize);int target = totalSum / 2;int dp[stonesSize][target + 1];// 初始化dp数组for (int j = 0; j <= target; j++) {if (j < stones[0]) {dp[0][j] = 0;} else {dp[0][j] = stones[0];}}for (int i = 1; i < stonesSize; i++) {for (int j = 0; j <= target; j++) {if (j < stones[i]) {dp[i][j] = dp[i - 1][j];} else {dp[i][j] = maxFun(dp[i - 1][j], dp[i - 1][j -stones[i]] + stones[i]);}}}return ((totalSum - dp[stonesSize - 1][target]) - dp[stonesSize - 1][target]);
}
dp[j]

分为两个子集,使其重量和最相近,此时剩余重量最小
压缩dp[i][j]为dp[j]: 在[0, i]中, 不大于重量j的石头重量和
dp[j] = max(dp[j], dp[j-stones[i]]+stones[i])

int sumFun(int *stones, int stonesSize)
{int sum = 0;for (int i = 0; i < stonesSize; i++) {sum += stones[i];}return sum;
}int maxFun(int p1, int p2)
{return p1 > p2 ? p1 : p2;
}int lastStoneWeightII(int* stones, int stonesSize) {int totalSum = sumFun(stones, stonesSize);int target = totalSum / 2;int dp[target + 1];// 初始化dp数组for (int j = 0; j <= target; j++) {dp[j] = 0;}// 遍历石头,从大到小遍历targetfor (int i = 0; i < stonesSize; i++) {for (int j = target; j >= stones[i]; j--) {dp[j] = maxFun(dp[j], dp[j -stones[i]] + stones[i]);}}return ((totalSum - dp[target]) - dp[target]);
}

[494] 目标和

题目描述

494 目标和
494 目标和

解题思路

前提:运算结果等于 target 的数量,target = left - right ,sum = left + right
思路:推到可知 left = (target + sum) / 2,转化为数组[0, i]中数值之和恰好等于left的数目,0-1背包问题 dp[i][j] = dp[i - 1][j] + dp[i - 1][j - num[i]]
重点:问题的转化,dp[i][j] 数组的初始化,以及公式推导

代码实现

C语言
dp[i][j]

dp[i][j]数组初始化,是个大问题!!!
关注数组全0情况~

// target = left - right
// sum = left + right
// left = (target + sum) / 2
// dp[i][j]: [0, i]中数值之和q恰好=left的数目
// dp[i][j] = dp[i - 1][j] + dp[i - 1][j - num[i]]int sumFun(int *nums, int numsSize)
{int totalSum = 0;for (int i = 0; i < numsSize; i++) {totalSum += nums[i];}return totalSum;
}int findTargetSumWays(int* nums, int numsSize, int target) {int sum = sumFun(nums, numsSize);// 考虑target为负数的情况if ((sum < target) || ((sum + target) < 0) || ((target + sum) % 2 == 1)) {return 0;}int left = (target + sum) / 2;int dp[numsSize][left + 1];// dp初始化dp[0][0] = 1;for (int j = 0; j <= left; j++) {dp[0][j] = 0;if (j == 0) {dp[0][0] = 1;}if (j == nums[0]) {dp[0][j] += dp[0][j - nums[0]];}}// 遍历数组元素及left大小for (int i = 1; i < numsSize; i++) {for(int j = 0; j <= left; j++) {dp[i][j] = dp[i - 1][j];if (j >= nums[i]) {dp[i][j] += dp[i - 1][j - nums[i]];}printf("%d ", dp[i][j]);}printf("\n");}return dp[numsSize - 1][left];
}
dp[j]
// target = left - right
// sum = left + right
// right = (sum - target) / 2, 这样可以避免考虑target为很大负值的特殊情况
// 压缩为滚动一维数组dp[j]: [0, i]中数值之和恰好=right的数目
// dp[j] = dp[j] + dp[j - num[i]]int sumFun(int *nums, int numsSize)
{int totalSum = 0;for (int i = 0; i < numsSize; i++) {totalSum += nums[i];}return totalSum;
}int findTargetSumWays(int* nums, int numsSize, int target) {int sum = sumFun(nums, numsSize);if ((sum < target) || ((sum - target) % 2 == 1)) {return 0;}int right = (sum - target) / 2;int dp[right + 1];// dp初始化dp[0] = 1;for (int j = 1; j <= right; j++) {dp[j] = 0;}// 遍历数组元素, 从大到小遍历right大小for (int i = 0; i < numsSize; i++) {for(int j = right; j >= nums[i]; j--) {if (j >= nums[i]) {dp[j] += dp[j - nums[i]];}}}return dp[right];
}

[474] 一和零

题目描述

474 一和零
474 一和零

解题思路

前提:虽然有“最多”的字眼,但是对于数组strs来说,还是最多只取一个元素,所以还是0-1背包问题
思路:该背包的维度是两个,str的遍历另算,所以非滚动数组是个三维数组,为了赋值方便,直接使用滚动二维数组实现
重点:问题的区分,dp[i][j] 数组的初始化,以及公式推导

代码实现

C语言
滚动数组dp[i][j],背包的维度是两个,str的遍历另算
// 此处的dp[i][j]是滚动数组,背包的维度是两个,str的遍历另算
// dp[i][j]: 最多有i个0, j个1的strs的子集的最大长度
// dp[i][j] = max(dp[i][j], dp[i-zeroNum][j-oneNum]+1)int maxFun(int p1, int p2)
{return p1 > p2 ? p1 : p2;
}int findMaxForm(char** strs, int strsSize, int m, int n) {int dp[m + 1][n + 1];// 初始化dpfor (int i = 0; i <= m; i++) {for (int j = 0; j <= n; j++) {dp[i][j] = 0;}}// 遍历strs数组, 并且从大到小遍历m和n两个维度的背包for (int s = 0; s < strsSize; s++) {// 计算该字符串的0和1个数int zeroNum = 0;int oneNum = 0;for (int k = 0; k < strlen(strs[s]); k++) {if (strs[s][k] == '0') {zeroNum++;} else {oneNum++;}}// 0-1背包, 从大到小遍历m和n两个维度的背包for (int i = m; i >= zeroNum; i--) {for (int j = n; j >= oneNum; j--) {dp[i][j] = maxFun(dp[i][j], dp[i - zeroNum][j - oneNum] + 1);}}}return dp[m][n];
}

今日收获

  1. 0-1背包问题:问题的转化与识别,dp数组的初始化、dp公式推导

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

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

相关文章

生命在于学习——Python人工智能原理(3.5)

三、深度学习 9、常见神经网络 常见的神经网络有卷积神经网络&#xff08;AlexNet、VGGNet&#xff09;、循环神经网络&#xff08;RNN&#xff09; 长短时记忆网络&#xff08;LSTM&#xff09;。 &#xff08;1&#xff09;AlexNet AlexNet于2012年由Hinton学生Alex提出&a…

uniapp顶部导航栏实现自定义功能按钮+搜索框并监听响应事件

目录 第一步&#xff1a;先下载按钮需要展示的图标&#xff08;若不使用图标&#xff0c;直接使用文字可跳过这步&#xff09; 1、点击需要的图标&#xff0c;添加入库 2、点击旁边的购物车&#xff0c;在弹出的窗口中选择下载代码 3、解压下载的压缩包&#xff0c;将这几个…

文章解读与仿真程序复现思路——电网技术EI\CSCD\北大核心《考虑绿证—碳交易的多能互补综合能源系统电—热—气协同低碳优化调度 》

本专栏栏目提供文章与程序复现思路&#xff0c;具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源…

【Seata】分布式事务解决方案——理论

目录 回顾什么是事务数据库事务的四大特性&#xff1a;ACID 分布式事务解释面临挑战分布式事务产生场景1. 单体架构中多数据源场景2. 分布式架构场景 分布式事务解决方案jta AtomikosLCN模式问题 Alibaba的Seata解决分布式事务问题 使用MQ解决分布式事务问题问题1&#xff1a;…

【Java】已解决Java中的com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException异常

文章目录 一、分析问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项 已解决Java中的com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException异常 在Java中操作MySQL数据库时&#xff0c;我们经常会使用JDBC&#xff08;Java Database Connectivi…

js中!emailPattern.test(email) 的test是什么意思

test 是 JavaScript 正则表达式&#xff08;RegExp&#xff09;对象的方法之一&#xff0c;用于测试一个字符串是否与正则表达式匹配。正则表达式是一种用于匹配字符串的模式&#xff0c;通常用于验证输入数据、查找和替换文本等。 使用 test 方法 test 方法语法如下&#xf…

Microsoft Remote Desktop:随时随地,掌控你的桌面

Microsoft Remote Desktop是一款卓越的远程桌面连接工具&#xff0c;由微软公司精心打造&#xff0c;旨在为用户提供高效、安全且便捷的远程办公体验。 Microsoft Remote Desktop mac版获取 这款软件支持跨平台操作&#xff0c;无论是在Windows、macOS还是iOS等设备上&#xf…

Idea连接GitLab的过程以及创建在gitlab中创建用户和群组

上期讲述了如何部署GitLab以及修复bug&#xff0c;这期我们讲述&#xff0c;如何连接idea。 首先安装gitlab插件 下载安装idea上并重启 配置ssh免密登录 使用管理员打开命令行输入&#xff1a;ssh-keygen -t rsa -C xxxaaa.com 到用户目录下.ssh查看id_rsa.pub文件 打开复制…

三分钟了解链动3+1模式

在电商领域的营销策略中&#xff0c;链动31模式以其独特的魅力和优势&#xff0c;吸引了众多商家的目光。下面&#xff0c;我们将对这一模式进行深度剖析&#xff0c;并探讨其相较于链动21模式的优势所在。 一、身份设置与奖励机制 链动31模式在身份设置上分为三种&#xff1…

漏洞挖掘 | 记一次某src拿下高危漏洞

一、获取web端管理员权限 0x01简单查看一下&#xff0c;发现存在登录以及证书查询操作指南等功能 因该站特征较为明显&#xff0c;所以对页面进行了强打码 0x02弱口令测试&#xff08;无成果&#xff09; 既然存在登录口&#xff0c;那么肯定要试试弱口令了&#xff0c;开干…

解锁微信客服的潜力:提升客户满意度与忠诚度

随着全球数字化进程的加速&#xff0c;企业如何有效利用数字化工具提升服务质量和客户满意度&#xff0c;成为了企业国际化、数字化出海的关键。在这一大背景下&#xff0c;微信客服以其卓越的功能和广泛的用户基础&#xff0c;成为了企业数字化转型的重要助力。 一、微信客服…

从零开始理解 XML 和 JSON 的区别

在这篇文章中&#xff0c;我们将深入探讨XML和JSON这两种数据格式的关键异同点&#xff0c;以便读者可以根据项目需求做出明智的技术选择。 了解XML XML&#xff08;Extensible Markup Language&#xff09;是一种用于数据定义的标记语言&#xff0c;最初由万维网联盟&#x…

【笔记】【矩阵的二分】668. 乘法表中第k小的数

力扣链接&#xff1a;题目 参考地址&#xff1a;参考 思路&#xff1a;二分查找 把矩阵想象成一维的已排好序的数组&#xff0c;用二分法找第k小的数字。 假设m行n列&#xff0c;则对应一维下标范围是从1到mn&#xff0c;初始&#xff1a; l1; rmn; mid(lr)/2 设mid在第i行&a…

新兴互联网银行搭档Apache SeaTunnel构建数据流通管道!

当新兴互联网银行乘着数字化改革的风潮搭档数据集成平台Apache SeaTunnel&#xff0c;成千万上亿的数据就有了快速流通的管道。6月26日14:00&#xff0c;Apache SeaTunnel社区将带上企业最佳实践与观众见面&#xff0c;与大家面对面交流最新的企业实践部署经验。锁定SeaTunnel视…

[spring] Spring MVC Thymeleaf(上)

[spring] Spring MVC & Thymeleaf&#xff08;上&#xff09; 本章内容主要过一下简单的 Spring MVC 的案例 简单来说&#xff0c;spring mvc 就是比较传统的网页开发流程&#xff0c;目前 boot 是可以比较轻松的配置 thymeleaf——毕竟 spring boot 内置对 thymeleaf 的…

未授权访问漏洞总结

以下总结了常见的未授权访问漏洞&#xff0c;还在持续更新中&#xff0c;遇到就会补充。欢迎大家关注~ 目录 FTP未授权访问&#xff08;21&#xff09; 漏洞原理 漏洞检测 漏洞利用 漏洞修复 LDAP未授权访问&#xff08;389&#xff09; 漏洞原理 漏洞检测 漏洞利用 …

Mongodb介绍及window环境安装

本文主要内容为nosql数据库-MongoDB介绍及window环境安装。 目录 什么是MongoDB&#xff1f; 主要特点 MongoDB 与Mysql对应 安装MongoDB 下载MongoDB 自定义安装 创建目录 配置环境变量 配置MongoDB服务 服务改为手动 启动与关闭 安装MongoDB Shell 下载安装包 …

三:SpringBoot的helloworld和使用Springboot的优点以及快速创建Springboot应用

三&#xff1a;SpringBoot的helloworld和使用Springboot的优点以及快速创建Springboot应用 一&#xff1a;HelloWorld [我们创建的是maven项目或者直接创建一个Spring] 1.1&#xff1a;创建一个maven 项目&#xff08;1】&#xff1a;需要自己手动写一个SpringBoot 的启动类同…

为什么网上这么多破解 Intellij IDEA 的工具,但是官方却不管呢?

大家好&#xff0c;我是小2&#xff0c;一个程序员~ 程序员小2 每天一篇技术重磅好文&#xff0c;涉及一线互联网大厂应用架构&#xff08;高可用、高性能、高稳定&#xff09;&#xff0c;AI、大数据、java架构等热门领域。 112篇原创内容 公众号 来源&#xff1a;Java知音…

基于Spring Boot+VUE旅游管理系统

1管理员功能模块 管理员通过点击后台管理&#xff0c;进入页面可以输入用户名、密码、角色进行登录相对应操作&#xff0c;如图1所示。 图1管理员登录界面 管理员通过点击后台管理&#xff0c;进入页面可以填写首页、个人中心、用户管理、旅游方案管理、旅游购买管理、系统管…