Day 40算法记录|dp完全背包问题 06

news2024/10/1 1:29:21

完全背包问题

  • 基本知识
    • 01背包
    • 完全背包
  • 518. 零钱兑换 II
    • 377. 组合总和 Ⅳ

基本知识

01背包

二维,两层for循环的循序,物品和背包不重要。
d p [ i ] [ j ] = m a x ( d p [ i − 1 ] [ j ] , d p [ i − 1 ] [ j − w e i g h t [ i ] ] + v a l u e [ i ] ) dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]) dp[i][j]=max(dp[i1][j],dp[i1][jweight[i]]+value[i]); 递归公式中可以看出 d p [ i ] [ j ] dp[i][j] dp[i][j]是靠 d p [ i − 1 ] [ j ] dp[i-1][j] dp[i1][j] d p [ i − 1 ] [ j − w e i g h t [ i ] ] dp[i - 1][j - weight[i]] dp[i1][jweight[i]]推导出来的。
一维滚动数组,只能先物品后背包

完全背包

这个视频讲了完全背包和01背包的区别
在这里插入图片描述
代码模板:
在这里插入图片描述在完全背包问题,对于一维dp数组来说,其实两个for循环嵌套顺序是无所谓的!
关键在于:为什么完全背包容量是从小到大遍历
因为01里面的,选择当前商品时,从大到小遍历,dp[j - coins[i]]表示前(i-1)种物品被选中的情况。
完全里面,选择当前商品时,一个物品可以选多次,所以dp[j - coins[i]]表示当前商品以前也可以被选择。

518. 零钱兑换 II

纯完全背包求得装满背包的最大价值是多少,和凑成总和的元素有没有顺序没关系
求凑出来的方案个数,且每个方案个数是为组合数。

在求装满背包有几种方案的时候,认清遍历顺序:
如果求组合数就是外层for循环遍历物品,内层for遍历背包。
如果求排列数就是外层for遍历背包,内层for循环遍历物品。

1.是组合数:dp[j]:凑成总金额j的货币组合数为dp[j]
所以遍历当前容量时候
(1).选 dp[j-coins[i]] (2).不选,dp[j]

2.递推公式:dp[j] += dp[j - coins[i]];
3.初始化;j-coins[i] == 0的情况表示这个硬币刚好能选

class Solution {
    public int change(int amount, int[] coins) {
     
     int[] dp = new int[amount+1];
     dp[0] = 1; //初始化 
     for(int i=0;i<coins.length;i++){
         for(int j= coins[i] ;j<= amount ;j++){
            dp[j] = dp[j]+dp[j-coins[i]];
         }
     }
     return dp[amount];
    }
}

377. 组合总和 Ⅳ

如果求组合数就是外层for循环遍历物品,内层for遍历背包。
如果求排列数就是外层for遍历背包,内层for循环遍历物品。

题目要求的是顺序不同的序列被视作不同的组合。
所以就是for循环背包,再循环物品

视频讲解:

这个讲了为啥外侧是包容量,因为顺序不同的序列被视作不同的组合

class Solution {
    public int combinationSum4(int[] nums, int target) {
        
   //存在数组中的元素能求出
     int[] dp = new int[target+1];
     dp[0] = 1;

     for(int i = 1;i<= target;i++){
         for(int j = 0;j<nums.length;j++){
            if(i>=nums[j]) {   // 只有当前包容量大于等于物品时候才考虑装不装
                dp[i] = dp[i] + dp[i-nums[j]];
            }
         }
     }
     return dp[target];
    }
}

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

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

相关文章

docker基础6——制作镜像(dockerfile)

文章目录 一、基本了解1.1. 基于centos构建镜像1.2 基于alpine制作镜像 二、常用指令三、制作httpd镜像 一、基本了解 Dockerfile 是一个文本格式的配置文件&#xff0c;可以使用Dockerfile 快速创建自定义镜像。Dockerfile 由一行行命令语句组成&#xff0c;并且支持以 # 开头…

Python实现HBA混合蝙蝠智能算法优化XGBoost分类模型(XGBClassifier算法)项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档视频讲解&#xff09;&#xff0c;如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 蝙蝠算法是2010年杨教授基于群体智能提出的启发式搜索算法&#xff0c;是一种搜索全局最优解的有效方法…

PROFINET转TCP/IP网关profinet网线接头接法

大家好&#xff0c;今天要和大家分享一款自主研发的通讯网关&#xff0c;捷米JM-PN-TCPIP。这款网关可是集多种功能于一身&#xff0c;PROFINET从站功能&#xff0c;让它在通讯领域独领风骚。想知道这款网关如何实现PROFINET和TCP/IP网络的连接吗&#xff1f;一起来看看吧&…

MySQL:JDBC编程

在实际开发中&#xff0c;SQL很少是手动输入的&#xff0c;绝大多数的SQL都是通过代码&#xff0c;自动执行的。这个时候就需要其他编程语言来操作数据库服务器。 自己写一个数据库客户端是非常容易的&#xff0c;各种数据库本身就提供了一系列的API&#xff0c;但是自己写一个…

ActivityWatch配置跨平台同步(放弃)

老版本探索 老版本启动aw_qt.exe报错如下&#xff1a; 解决方案: ActivityWatch\activitywatch\PyQt5\Qt\plugins\platforms 复制到 ActivityWatch\activitywatch 下面重新启动aw_qt.exe即可解决 最新版 具体内容如下&#xff1a; Traceback (most recent call last): …

【前端】解决element-ui的form组件resetFields()方法不生效的问题

问题 使用element-ui的form组件&#xff0c;在输入栏较多的时候&#xff0c;有时resetFields只能重置一部分输入框的值 解决 给每个值赋值初始值为空即可 例如&#xff0c;需要清除的:model"queryForm.bgnTime"、:model"queryForm.endTime"等一系列的值…

基于Java+SpringBoot+vue前后端分离阿博图书馆管理系统设计实现

博主介绍&#xff1a;✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专…

【Boost搜索引擎项目】

文章目录 一、项目流程二、项目展示 一、项目流程 1.编写数据去标签模块–parser.cc 将去标签之后干净文档以title\3content\3url\ntitle\3content\3url\n格式放入同一文件中。 2.建立索引模块–index.hpp 读取处理好的行文本文件进行分词、权重计算等操作&#xff0c;在内存中…

ICMP_1靶场详解

ICMP_1靶场复盘 这个靶场还是很有意思的&#xff0c;尤其在提权阶段。 靶场下载地址&#xff1a;https://download.vulnhub.com/icmp/icmp.ova.gz arp-scan --localnet首先扫描ip&#xff0c;登陆后发现是个这样的页面。 我们发现这个页面在提醒我们的就是出现了monitorr 然…

如何部署MHA高可用MySQL数据库

目录 一、MHA概念 MHA 的组成 MHA 的特点 MHA工作原理 二、部署MySQL数据库MHA高可用 第一步 关闭所有防火墙和安全机制 第二步 修改主数据库配置文件 第三步 修改从数据库的配置文件 第四步 重启服务 第五步 优化所有数据库路径 第六步 授权所有数据库节点 第七步…

nodejs+vue+elementui在线课程知识点管理系统

前端技术&#xff1a;nodejsvueelementui,视图层其实质就是vue页面&#xff0c;通过编写vue页面从而展示在浏览器中&#xff0c;编写完成的vue页面要能够和控制器类进行交互&#xff0c;从而使得用户在点击网页进行操作时能够正常。 可以设置中间件来响应 HTTP 请求。 对于之前…

C++ 使用tinyxml库处理XML文件

文章目录 前言一、下载tinyxml二、创建一个XML文件三、XML文件增加数据四、修改XML文件五、解析XML文件六、XML文件删除数据总结 前言 TinyXML是一个开源的解析XML的解析库&#xff0c;能够用于C&#xff0c;能够在Windows或Linux中编译。这个解析库的模型通过解析XML文件&…

解决使用@Field注解配置分词器失效问题(Spring Data Elasticsearch)

问题复现&#xff1a;插入数据时&#xff0c;实体类配置的Field注解没有生效 实体类&#xff1a; package cn.aopmin.pojo;import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import org.springframework.data.annotation.Id; import…

机器学习李宏毅学习笔记38

文章目录 前言一、生成式学习二、各个击破和一次到位的对比1.各个击破&#xff08;Autoregressive(AR) model&#xff09;2.一次到位&#xff08;Non-autoregressive(NAR) model&#xff09; 总结 前言 生成式学习两种策略&#xff1a;各个击破/一次到位 有结构的生成物比如语…

【vue3】常见的使用vue3创建项目的几种方法

1、使用ui界面创建&#xff0c;winr打开命令提示符&#xff0c;输入vue ui 2、winr打开命令提示符&#xff0c;输入vue create 项目名称 3、使用脚手架创建 其中方法一&#xff0c;方法二是使用npm run serve来运行的&#xff0c;方法三是使用npm run dev运行的

基于MOT数据集的高精度行人检测系统(PyTorch+Pyside6+YOLOv5模型)

摘要&#xff1a;基于MOT数据集的高精度行人检测系统可用于日常生活中检测与定位行人目标&#xff0c;利用深度学习算法可实现图片、视频、摄像头等方式的行人目标检测识别&#xff0c;另外支持结果可视化与图片或视频检测结果的导出。本系统采用YOLOv5目标检测模型训练数据集&…

react native 本地存储 AsyncStorage

An asynchronous, unencrypted, persistent, key-value storage system for React Native. Async Storage 只能用来储存字符串数据&#xff0c;所以为了去储存object类型的数据&#xff0c;得先进行序列化&#xff08;JSON.stringify()&#xff09;当你想要使用数据的时候&…

redis(9):spring里面使用redis

1 创建一个mave项目 自行创建一个maven项目 2 修改pom.xml <properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><maven.compiler.source>1.7</maven.compiler.source><maven.compiler.target>1.7</maven…

Python电商爬虫保姆级入门教程(纯新手向)

图灵Python课堂 长沙图灵教育于2001年开始进入教育行业&#xff0c;立足泛IT类职业教育&#xff0c;以打造高新技术人才为宗旨&#xff0c;专注于提供多层次、个性化的职业技能培训课程&#xff0c;为各行业培养技术开发、应用和管理等岗位的中高端人才&#xff0c;致力于成为…

vue全局状态管理工具 Pinia 的使用

先了解一下关于Pinia的一些故事&#xff0c;面试把这些讲给面试官挺加分的&#xff0c;同时这是我持续学习下去的动力 1.为什么叫Pinia&#xff1f; 官网解释是西班牙语中的 pineapple&#xff0c;即“菠萝”&#xff0c;菠萝花是一组各自独立的花朵&#xff0c;它们结合在一起…