【Day51】代码随想录之动态规划完全背包_139.单词拆分_背包总结

文章目录

      • 动态规划理论基础
        • 动规五部曲:
        • 出现结果不正确:
      • 139.单词拆分
      • 背包问题
        • 0-1背包
        • 完全背包

动态规划理论基础

动规五部曲:
  1. 确定dp数组 下标及dp[i] 的含义。
  2. 递推公式:比如斐波那契数列 dp[i] = dp[i-1] + dp[i-2]。
  3. 初始化dp数组。
  4. 确定遍历顺序:从前到后or其他。
  5. 打印。
出现结果不正确:
  1. 打印dp日志和自己想的一样:递推公式、初始化或者遍历顺序出错。
  2. 打印dp日志和自己想的不一样:代码实现细节出现问题。

139.单词拆分

参考文档:代码随想录

分析:

  1. 将字符串s作为背包,字符数组作为物品,装入背包;
  2. 背包内的物品要求是有顺序的,所以物品装入背包是排列,遍历顺序是先背包再物品。
  3. dp[i]表示的含义是字符串的0-i是否能与字符串组中的字符串匹配,匹配为true,结果是如果dp[s.size()] == true; return true;
  4. 递推公式是:从i位置往前截取j个单位,如果[i-j, i]切割的字符串出现在了字符数组中且i-j位置的dp为true,更新dp[i-j, i] = true; 即if([i-j] ∈ wordDict && dp[i-j] == true) dp[i] = true。

代码:

class Solution {
public:bool wordBreak(string s, vector<string>& wordDict) {//将s设为背包//wordDict中的单词再s中是否有合适的排列数(强调顺序与s的顺序一致)//wordDict中的单词可以无限使用,完全背包问题unordered_set<string> wordSet(wordDict.begin(), wordDict.end());vector<bool> dp(s.size() +1, false);dp[0] = true;for(int i = 1; i <= s.size(); i++){for(int j =  1; j <= i; j++){string tmp = s.substr(i-j,j);if(wordSet.find(tmp) != wordSet.end() && dp[i-j]){dp[i] = true;}}}return dp[s.size()];}
};

背包问题

参考:代码随想录
在物品的数量只有一个还是无数个上面

0-1背包

每个物品的数量只有一个
二维数组:f背包,物品遍历顺序任意
滚动数组:必须先物品再背包,背包的遍历顺序为倒序。
应用:

  1. 背包装物品的最大价值数:dp[j] = max(dp[j], dp[j-nums[j]]+vaule[i]);
  2. 装满背包方法数:dp[j] += dp[j-nums[i]];
  3. 能否装满背包:dp[j] = max(dp[j], dp[j-nums[j]]+vaule[i]); return dp[last] == target;
  4. 装满背包的最小物品数:dp[j] = min(dp[j], dp[j-nums[i]]+1);
完全背包

每个物品的数量有无数个
滚动数组的背包和物品的遍历顺序任意,内层循环体必须从小到大,有累加效果。
应用:

  1. 排列数:先背包再物品,给出一个集合和目标值。
  2. 组合数:先物品再背包,给出一个集合和目标值。
  3. 求满足的最小方法数
  4. 单词拆分:截取字串与字符数组匹配再结合截取位置的dp值判断当前位置的dp值。

相关题目:
代码随想录
在这里插入图片描述

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

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

相关文章

uniapp不同平台获取文件内容以及base64编码特征

前言 文件图片上传&#xff0c;客户端预览是很正常的需求&#xff0c;获取文件的md5特征码也是很正常的&#xff0c;那么&#xff0c;在uniapp中三种环境&#xff0c;h5, 小程序以及 app环境下&#xff0c;如何实现的&#xff1f; 参考&#xff1a; 如何在uniapp中读取文件Arr…

Guitar Pro 8.1 Mac 2024最新下载、安装、激活、换机图文教程

Guitar Pro 8是吉他手的终极工具箱,也是阅读和编辑乐谱的领先软件。26 年来,Guitar Pro 一直在帮助世界各地的音乐家学习弹吉他、创作歌曲以及转录和编辑歌集。 Guitar Pro是一款专业的吉他制谱软件&#xff0c;现在已更新至Guitar Pro8&#xff0c;新增了支持添加音频轨道、支…

C++拷贝构造函数与赋值运算符重载

顾得泉&#xff1a;个人主页 个人专栏&#xff1a;《Linux操作系统》 《C从入门到精通》 《LeedCode刷题》 键盘敲烂&#xff0c;年薪百万&#xff01; 一、拷贝构造函数 1.概念 在现实生活中&#xff0c;可能存在一个与你一样的自己&#xff0c;我们称其为双胞胎。 那在创…

ClickHouse 基础(一)

官网 ClickHouse release 24.1, 2024-01-30 以毫秒为单位查询数十亿行 ClickHouse是用于实时应用和分析的最快、资源效率最高的开源数据库。 安装ClickHouse 使用ClickHouse&#xff0c;你有三个选择: ClickHouse云:官方ClickHouse作为一项服务&#xff0c;-由ClickHouse的创…

openGauss 5.0.0全密态数据库应用小试

前言 openGauss HCIA教材中&#xff0c;安全是一个重要的章节&#xff0c;在实际项目中&#xff0c;随着网络安全和信息安全形势的变化&#xff0c;企业也越来越重视数据库安全。去年在HALP内部进行openGauss培训时&#xff0c;安全特性就被学员们提出来要重点讲解&#xff0c…

免费改文案的软件有哪些,为大家分享四款!

随着数字化时代的到来&#xff0c;文案写作已经成为许多企业和个人必备的技能。要在众多文案中脱颖而出并不容易。所幸的是&#xff0c;如今有许多免费改文案的软件可以帮助我们快速而高效地完成这项工作。本文将介绍一些常见的免费改文案的软件&#xff0c;帮助大家选择适合自…

【C++】vector模拟实现+迭代器失效

vector模拟实现 成员变量定义默认成员函数构造函数 迭代器范围for、对象类型匹配原则 容量操作sizeemptycapacityreserve成员变量未更新memcpy值拷贝 resize内置类型的构造函数 数据访问frontbackoperator[ ] 数据修改操作push_backpop_backswapclearinsertpos位置未更新无返回…

2、windows环境下vscode开发c/c++环境配置(一)

前言&#xff1a;VSCode是微软出的一款轻量级编辑器&#xff0c;它本身只是一款文本编辑器而已&#xff0c;并不是一个集成开发环境(IDE)&#xff0c;几乎所有功能都是以插件扩展的形式所存在的。因此&#xff0c;我们想用它编程&#xff0c;不只是把vscode下载下来就行&#x…

卡诺模型驱动人工智能革新:重塑未来智能生态!

在数字化浪潮席卷全球的今天&#xff0c;人工智能&#xff08;AI&#xff09;已成为推动社会进步的重要力量。而卡诺模型&#xff0c;作为一种经典的产品设计和优化工具&#xff0c;正以其独特的视角和强大的分析能力&#xff0c;为人工智能领域注入新的活力&#xff0c;赋能AI…

GPIO控制和命名规则

Linux提供了GPIO子系统驱动框架&#xff0c;使用该驱动框架即可灵活地控制板子上的GPIO。 GPIO命名 泰山派开发板板载了一个40PIN 2.54间距的贴片排针&#xff0c;排针的引脚定义兼容经典40PIN接口。 在后续对GPIO进行操作前&#xff0c;我们需要先了解k3566的GPIO命名规则&a…

城市级智慧排水管网监测,综合预警管理系统

通过城市智慧排水管网监测系统的建设&#xff0c;实现对管网上窨井井盖状态、管网液位、管网流量、管网有害气体、管网水质等数据采集&#xff0c;实时掌握排水管网运行状况&#xff0c;为排水管网的运行调度、养护管理、快速响应提供有效的数据支持&#xff0c;以便于管理者掌…

2024年护眼大路灯横评推荐:书客、霍尼韦尔、松下落地灯哪款才是性能之王?

大路灯逐渐成为学生党、上班族的必备家电&#xff0c;但很多朋友对大路灯了解较少&#xff0c;对大路灯怎么选还有很多疑问&#xff0c;市场大路灯品牌、型号琳琅满目&#xff0c;不知道大路灯哪个品牌好&#xff1f; 本文通过对市面上热门品牌型号测评对比&#xff0c;系统性介…