day49--动态规划8

news2025/1/15 6:46:54
  •  139.单词拆分 
  •  关于多重背包,你该了解这些! 
  •  背包问题总结篇!

第一题:单词拆分

给定一个非空字符串 s 和一个包含非空单词的列表 wordDict,判定 s 是否可以被空格拆分为一个或多个在字典中出现的单词。

说明:

拆分时可以重复使用字典中的单词。

你可以假设字典中没有重复的单词。

示例 1:

  • 输入: s = "leetcode", wordDict = ["leet", "code"]
  • 输出: true
  • 解释: 返回 true 因为 "leetcode" 可以被拆分成 "leet code"

感觉用背包做这道题不是很好理解。

单词作为物品,字符串S就是背包,单词能否组成字符串S,就是问物品能不能把背包装满,意思就是说字符串的单词必须全部由单词表里的部分单词组成?

动态规划五部曲:

(1)确定dp数组以及下标含义

dp[i]: 字符串长度为i的话,dp[i]为true,表示可以拆分成一个或多个在字典中出现的单词。

(2)确定递推公式

站在前面往后看,如果dp[j]=true的话,且[j,i]这个区间的子串出现在字典中,那么dp[i]一定也是true;

就是说,如果前面已经是true了,后面的子串也在字典中,自然dp[i]就是true,如果前面是true,但是子串没在字典中,那么dp[i]是false

(3)dp数组如何初始化。

根据递推公式dp[i]依赖dp[j],所以dp[0]就是根基,比如(0,1)子串在字典中,那么dp[1]是否是true就取决于dp[0]了,所以dp[0]肯定为true;

(4)确定遍历顺序

本题,物品(单词)可以无限次使用,目的是将背包装满,同时单词的拿取有顺序,只有这样才能组成正确的字符串。所以是排列问题

排列问题:外层先遍历背包,内层后遍历物品。

(5)举例推导dp[i]

第二题:多重背包问题

有N种物品和一个容量为V的背包,第i种物品最多有Mi件可用,每件耗费的空间是Ci,价值是Wi。

求解将哪些物品装入背包可使这些物品的耗费的空间总和不超过背包容量,且价值总和最大。

和之前的不同:物品数量不一样。但将所有物品张开其实和01背包一样。

背包问题总结:

不论题目如何描述,涉及容量的是背包,涉及价值体积数量的是物品。

动态规划五部曲:

  1. 确定dp数组(dp table)以及下标的含义
  2. 确定递推公式
  3. dp数组如何初始化
  4. 确定遍历顺序
  5. 举例推导dp数组
重点在递推公式,初始化根据递推公式决定dp[0]的值

1. 问能否装满背包(或者最多装多少):dp[j]=max(dp[j],dp[j-nums[i]]+nums[i]);

分割等和子集:用一个容量为sum/2的背包装子集

最后一块石头的重量:同理,用一个容量为sum/2的背包装子集,并求最后剩下的

2. 问装满背包有几种方法: dp[j]+=dp[j-nums[i]];

目标和:站在j位置上,等于原来的j-nums[i]的基础上加上nums[i].

零钱兑换2:

组合总和4

爬楼梯进阶版

3. 问背包装满最大价值:dp[j]=max(dp[j],dp[j-weight[i]]+value[i])

一和零:等等,有些不理解

4.问装满背包所有物品的最小个数:dp[j]=min(dp[j-coins[i]]+1,dp[j])

零钱兑换:用5,10,20装满背包

完全平方数:将满足条件的数求平方和满足target,等于求装满背包,只是多加了一步求平方

遍历顺序:

01背包:注意一维dp数组和二维dp数组

完全背包:一维dp数组实现,但是for循环的先后不一样

如果是求组合,外层先物品,内层再背包

如果是求排列,外层先背包,内层再物品

求组合数:零钱兑换2

求排列数:组合总和4、爬楼梯进阶版

求最小数:零钱兑换、完全平方数

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

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

相关文章

[Database] MySQL 8.x Window / Partition Function (窗口/分区函数)

🧲相关文章 [1] MySQL 系统表解析以及各项指标查询 [2] MySQL 5.7 JSON 字段的使用的处理 [3] MySQL经典练习50题 简介 MySQL 8.0版本开始支持窗口函数 官方文档 在之前的版本中已存在的大部分聚合函数,在MySQL 8 中也可以作为窗口函数来使用 方法 / …

地址空间收尾-进程控制

子进程为什么能继承父进程的环境变量呢?并且具有全局属性? 通过打印地址实验可以发现,进程的环境变量在栈区之上 父进程的环境变量也是由bash继承下来的,必定有页表帮助我们从虚拟到物理的映射,创建子进程的页表时也会…

PowerCLI 实现email发送消息

前提条件 开启wmi,配置网卡,参考 创建发送获取信息到邮件 最终实现获取esxi 主机版本信息, esxi 主机IP,esxi开机开启状态,虚拟机名称,虚拟机IP,虚拟机开机状态,虚拟机归属哪一个物理机,发送信息到邮箱。脚本解释以下全部注释解释,请你在#部分获取。powercli-send-e…

HTML页面获取URL传递的参数值

如: // 查询url上链接的参数与参数值 function getQueryString(name) {var url window.location.search; // 获取URLvar pattern new RegExp("[\?\&]" name "([^\&])", "i"); // 正则匹配URLvar matcher pattern.exec(…

村田:什么是UWB无线通信?使用UWB的定位方法有哪些应用 ​

UWB是Ultra-Wide Band的缩写,意思是超宽带。UWB无线通信是使用超宽带的频率带宽的无线通信,其主要特征是能够实现高精度定位。近年来,已普及至智能手机防丢失、高阶汽车智能钥匙等民用设备。预计未来将在多个领域普及。 UWB无线通信技术有哪些…

浙江环保用电计量adw300-hj治污产污生产设备监测

浙江环保用电计量表,浙江环保用电能表,浙江环保督查计量电表,环保设备能耗采集表 企业基本信息 企业名称:XXXXXXXXXXX 企业地址:XX省XX市 工 程 量:X台监测仪表 预计工期:X天 监测点位信息…

Git撤销已经push到远程分支的commit

有时想要撤销已经push到远程仓库的commit,将代码还原为commit之前的样子,应该如何做呢? 如果只有自己使用的分支:可以使用git reset命令 git log 查看需要还原的commitId,如下截图, 我们需要撤销ffe4a的…

【API篇】十、生成Flink水位线

文章目录 1、水位线的生成原则2、有序流内置水位线3、乱序流内置水位线4、自定义周期性水位线生成器5、自定义断点式水位线生成器6、从数据源中发送水位线 1、水位线的生成原则 水位线出现,即代表这个时间之前的数据已经全部到齐,之后不会再出现之前的数…

具有独特底部轮廓的剥离光刻胶的开发

引言 金属图案的剥离方法已广泛应用于各种电子器件的制造过程中,如半导体封装、MEMS和LED的制造。与传统的金属刻蚀方法不同的是,采用剥离法的优点是节省成本和工艺简化。在剥离过程中,经过涂层、曝光和开发过程后,光刻胶会在晶片…

最简单的Ubuntu更新Nvidia驱动的方法 解决nvidia-smi 不是内部或外部命令

在装有Ubuntu/Linux的服务器上遇到nvidia-smi不是内部或外部命令的问题,解决方法:更新英伟达驱动。 Ubuntu自带的“软件和更新”里可以方便地更新驱动,不需要从英伟达官网下载驱动。 我把它改成了第一项(原来是一个名为nouveau的…

点成案例 | 点成生物干浴器的多领域应用

前沿 在前面的文章中,我们给大家分享了点成生物水浴设备在食品行业的食物特性和生物活性测定的应用案例,本期文章将为大家详细介绍一下点成生物的干浴设备及其在多种领域中的应用。 一、干浴器简介 干浴器,又名恒温金属浴或金属浴。与水浴设…

好用的Visio绘图文件工具 VSD Viewer最新 for mac

VSD Viewer是一款可以查看Microsoft Visio绘图文件的工具,适用于Windows和macOS操作系统。它具有以下优点: 直观易用:VSD Viewer的用户界面非常简单直观,易于使用。支持多种文件格式:VSD Viewer支持多种Visio文件格式…

JavaScript函数:入门指南

目录 函数的定义和调用 函数参数 返回值 匿名函数 回调函数 箭头函数的定义和语法 箭头函数的参数和返回值 箭头函数的this绑定 递归函数简介 基本情况 递归调用 注意事项 递归的应用 JavaScript是一种广泛使用的编程语言,拥有强大的函数功能。函数是J…

Java基础——流程控制

文章目录 顺序结构分支结构ifif elseswitch 循环结构forwhiledo while嵌套循环 流程控制语句breakcontinuereturn 流程控制语句是用来控制程序中各语句执行顺序,可以把语句组合成能完成一定功能的小逻辑模块。 顺序结构 程序从上到下逐行执行,中间没有…

系统优化-异步化

目录 1:异步化 1.1:什么是同步?什么是异步? 1.2:异步化业务流程分析 1.3:异步化的问题 2:线程池的理论和实战 2.1:为啥需要线程池? 2.2:线程池的实现 2.2.1:线程池参数 2.2.2:线程池的工作机制 1:异步化 什么时候使用异步化? 调用的服务处理能力有限&#xff0c…

酷开科技 | 酷开系统大屏电视,打造精彩家庭场景

在信息资讯不发达的年代,电视机一直都是个人及家庭重要的信息获取渠道和家庭娱乐中心,是每个家庭必不可少的大家电之一!在快节奏的现代生活中,受手机和平板的冲击,电视机这个曾经的客厅“霸主”一度失去了“主角光环”…

Haproxy 服务

Haproxy:他也是常用的负载均衡软件 nginx 支持四层转发,七层转发 haproxy 也是四层和七层转发 LVS的DR和NAT都是基于四层转发 都是基于流量的转发。 tun:四层和七层都有。 基于四层的转发: 1,lvs 2,nginx 3&…

Go语言入门心法(十六):Go远程过程调用框架GRPC实战

Go语言入门心法(一): 基础语法 Go语言入门心法(二): 结构体 Go语言入门心法(三): 接口 Go语言入门心法(四): 异常体系 Go语言入门心法(五): 函数 Go语言入门心法(六): HTTP面向客户端|服务端编程 Go语言入门心法(七): 并发与通道 Go语言入门心法(八): mysql驱动安装报错o…

vue-admin相关问题记录

编辑器设置自定义高度 base.component.js内关于tinymce内容初始化设置&#xff0c;增加高度自定义接收并初始化 <tinymce :content.sync"form.article_content" :height"400"></tinymce> textarea自定义高度 tooltip备注