【背包问题】完全背包

目录

前言:

一,完全背包问题

问题描述:

模板题目:

 题目解析:

代码: 

空间优化:

二,典例

1,零钱兑换

 题目解析:

算法分析:

代码:

空间优化:

2,零钱兑换2

题目解析:

算法分析:

代码:

空间优化:

 3,完全平方数

题目解析:

算法解析:

代码: 

空间优化:


前言:

上篇:01背包CSDN

一,完全背包问题

问题描述:

        有n个物品,和一个容量为V的背包,每种物品都可以无限使用。每个物品都有两个属性,体积v和价值w。求解:将那些物品放入背包,可使这些物品的总体积不超过背包的容量,且总价值最大,输出最大价值。

        与01背包问题不同的是,完全背包的物品是可以无限选取的,而01背包的物品只会面临选或者不选。

模板题目:

题目链接:【模板】完全背包_牛客题霸_牛客网

 题目解析:

        与01背包问题相似,我们定义出状态表示:dp[i][j]表示,在前i个物品中选,总体积不超过j情况下,所能装的最大价值。

 

 

        对于第二问,状态表示为: dp[i][j]表示,在前i个物品中选,总体积正好等于j的情况下,所能装的最大价值。

代码: 

#include <iostream>
using namespace std;
#include <string.h>const int N=1010;
int n,V,v[N],w[N];
int  dp[N][N];
int main()
{cin>>n>>V;for(int i=1;i<=n;i++){cin>>v[i]>>w[i];}for(int i=1;i<=n;i++)for(int j=0;j<=V;j++){dp[i][j]=dp[i-1][j];if(j>=v[i])dp[i][j]=max(dp[i][j],dp[i][j-v[i]]+w[i]);}cout<<dp[n][V]<<endl;memset(dp,0,sizeof(dp));for(int j=1;j<=V;j++)dp[0][j]=-1;for(int i=1;i<=n;i++)for(int j=0;j<=V;j++){dp[i][j]=dp[i-1][j];if(j>=v[i]&&dp[i][j-v[i]]!=-1)dp[i][j]=max(dp[i][j],dp[i][j-v[i]]+w[i]);}cout<<(dp[n][V]==-1?0:dp[n][V])<<endl;return 0;
}

空间优化:

        利用滚动数组做空间上的优化,与01背包的原理相似

#include <iostream>
using namespace std;
#include <string.h>const int N=1010;
int n,V,v[N],w[N];
int  dp[N];
int main()
{cin>>n>>V;for(int i=1;i<=n;i++){cin>>v[i]>>w[i];}for(int i=1;i<=n;i++)for(int j=v[i];j<=V;j++){dp[j]=max(dp[j],dp[j-v[i]]+w[i]);}cout<<dp[V]<<endl;memset(dp,0,sizeof(dp));for(int j=1;j<=V;j++)dp[j]=-1;for(int i=1;i<=n;i++)for(int j=v[i];j<=V;j++){if(dp[j-v[i]]!=-1)dp[j]=max(dp[j],dp[j-v[i]]+w[i]);}cout<<(dp[V]==-1?0:dp[V])<<endl;return 0;
}

二,典例

1,零钱兑换

本题链接:LCR 103. 零钱兑换 - 力扣(LeetCode)

 

 题目解析:

        coins数组中不同面值的硬币,可以看成是n个物品。从coins数组中挑选硬币,使其总和等于amount的最少硬币数。其中,每种硬币是可以无线选取的。可以用完全背包的思路解题。

算法分析:

        

代码:
class Solution {
public:int coinChange(vector<int>& coins, int amount) {int n=coins.size();const int INF=0x3f3f3f3f;vector<vector<int>> dp(n+1,vector<int>(amount+1));for(int j=1;j<=amount;j++)dp[0][j]=INF;for(int i=1;i<=n;i++)for(int j=0;j<=amount;j++){dp[i][j]=dp[i-1][j];if(j>=coins[i-1])dp[i][j]=min(dp[i][j],dp[i][j-coins[i-1]]+1);}return dp[n][amount]>=INF?-1:dp[n][amount];}
};
空间优化:
class Solution {
public:int coinChange(vector<int>& coins, int amount) {int n=coins.size();const int INF=0x3f3f3f3f;vector<int> dp(amount+1);for(int j=1;j<=amount;j++)dp[j]=INF;for(int i=1;i<=n;i++)for(int j=coins[i-1];j<=amount;j++){dp[j]=min(dp[j],dp[j-coins[i-1]]+1);}return dp[amount]>=INF?-1:dp[amount];}
};

2,零钱兑换2

本题链接:518. 零钱兑换 II - 力扣(LeetCode)

题目解析:

        本题求的是不同的组合数,上题是求最少硬币数。

算法分析:

 

代码:
class Solution {
public:int change(int amount, vector<int>& coins) {int n = coins.size();//数据相加后 可能会超出范围vector<vector<double>> dp(n + 1, vector<double>(amount + 1, 0));dp[0][0] = 1;for (int i = 1; i <= n; i++)for (int j = 0; j <= amount; j++) {dp[i][j] = dp[i - 1][j];if (j >= coins[i - 1])dp[i][j] += dp[i][j - coins[i - 1]];}return dp[n][amount];}
};
空间优化:
class Solution {
public:int change(int amount, vector<int>& coins) {int n = coins.size();vector<double> dp(amount + 1);dp[0] = 1;for (int i = 0; i < n; i++)for (int j = coins[i]; j <= amount; j++)dp[j] += dp[j - coins[i]];return dp[amount];}
};

 3,完全平方数

本题链接:279. 完全平方数 - 力扣(LeetCode)

题目解析:

         一个整数n拆成几个完全平方数的和,求完全平方数的最少数量。

算法解析:

        对于一个整数n,我们在找它的完全平方数和时,只会在1到根号n之前找。比如中13的完全平方数,我们会找4和9,即2的平方和3的平方。

代码: 
class Solution {
public:int numSquares(int n) {int m=sqrt(n);vector<vector<int>> dp(m+1,vector<int>(n+1));for(int j=1;j<=n;j++)dp[0][j]=0x3f3f3f3f;for(int i=1;i<=m;i++)for(int j=0;j<=n;j++){dp[i][j]=dp[i-1][j];if(j>=i*i)dp[i][j]=min(dp[i][j],dp[i][j-i*i]+1);}return dp[m][n];}
};
空间优化:
class Solution {
public:int numSquares(int n) {int m=sqrt(n);vector<int> dp(n+1);for(int j=1;j<=n;j++)dp[j]=0x3f3f3f3f;for(int i=1;i<=m;i++)for(int j=i*i;j<=n;j++){dp[j]=min(dp[j],dp[j-i*i]+1);}return dp[n];}
};

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

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

相关文章

【Python实现机器遗忘算法】复现2023年TNNLS期刊算法UNSIR

【Python实现机器遗忘算法】复现2023年TNNLS期刊算法UNSIR 1 算法原理 Tarun A K, Chundawat V S, Mandal M, et al. Fast yet effective machine unlearning[J]. IEEE Transactions on Neural Networks and Learning Systems, 2023. 本文提出了一种名为 UNSIR&#xff08;Un…

知识管理平台在企业信息化建设中的应用价值与未来展望

内容概要 在当今信息化时代&#xff0c;企业面临着海量信息的挑战&#xff0c;知识管理平台因此应运而生&#xff0c;成为企业提升管理效率和决策能力的关键工具。知识管理平台不仅仅是一个信息存储的工具&#xff0c;它集成了信息共享、协作与创新、决策支持等多项功能。通过…

MiniHack:为强化学习研究提供丰富而复杂的环境

人工智能咨询培训老师叶梓 转载标明出处 想要掌握如何将大模型的力量发挥到极致吗&#xff1f;叶老师带您深入了解 Llama Factory —— 一款革命性的大模型微调工具&#xff08;限时免费&#xff09;。 1小时实战课程&#xff0c;您将学习到如何轻松上手并有效利用 Llama Facto…

从AD的原理图自动提取引脚网络的小工具

这里跟大家分享一个我自己写的小软件&#xff0c;实现从AD的原理图里自动找出网络名称和引脚的对应。存成文本方便后续做表格或是使用简单行列编辑生成引脚约束文件&#xff08;如.XDC .UCF .TCL等&#xff09;。 我们在FPGA设计中需要引脚锁定文件&#xff0c;就是指示TOP层…

MySQL分表自动化创建的实现方案(存储过程、事件调度器)

《MySQL 新年度自动分表创建项目方案》 一、项目目的 在数据库应用场景中&#xff0c;随着数据量的不断增长&#xff0c;单表存储数据可能会面临性能瓶颈&#xff0c;例如查询、插入、更新等操作的效率会逐渐降低。分表是一种有效的优化策略&#xff0c;它将数据分散存储在多…

HTML5使用favicon.ico图标

目录 1. 使用favicon.ico图标 1. 使用favicon.ico图标 favicon.ico一般用于作为网站标志&#xff0c;它显示在浏览器的地址栏或者标签上 制作favicon图标 选择一个png转ico的在线网站&#xff0c;这里以https://www.bitbug.net/为例。上传图片&#xff0c;目标尺寸选择48x48&a…

【C++动态规划 网格】2328. 网格图中递增路径的数目|2001

本文涉及知识点 C动态规划 LeetCode2328. 网格图中递增路径的数目 给你一个 m x n 的整数网格图 grid &#xff0c;你可以从一个格子移动到 4 个方向相邻的任意一个格子。 请你返回在网格图中从 任意 格子出发&#xff0c;达到 任意 格子&#xff0c;且路径中的数字是 严格递…

fatal error C1083: ޷[特殊字符]ļ: openssl/opensslv.h: No such file or directory

一、环境 1. Visual Studio 2017 2. edk2&#xff1a;202305 3. Python&#xff1a;3.11.4 二、 fatal error C1083: ޷&#xbfab0;ļ: openssl/opensslv.h: No such file or directory 上图出现这个警告&#xff0c;不用管。 出现Done&#xff0c;说明编译成功。 执行上…

组件框架漏洞

一.基础概念 1.组件 定义&#xff1a;组件是软件开发中具有特定功能或特性的可重用部件或模块&#xff0c;能独立使用或集成到更大系统。 类型 前端 UI 组件&#xff1a;像按钮、下拉菜单、导航栏等&#xff0c;负责构建用户界面&#xff0c;提升用户交互体验。例如在电商 AP…

隐藏字符造成的linux命令执行失败(非常难绷)

隐藏字符问题发生情景 事情是这样的&#xff0c;为了方便主机和虚拟机之间数据的传输&#xff0c;我打算建一个共享文件夹。由于我选择的是手动挂载&#xff0c;在VirtualBox 中创建好共享文件夹后&#xff0c;我着手打开Ubuntu&#xff0c;想将这个共享文件夹挂载到我的家目录…

C/C++ 虚函数

虚函数的定义 虚函数是指在基类内部声明的成员函数前面添加关键字 virtual 指明的函数虚函数存在的意义是为了实现多态&#xff0c;让派生类能够重写(override)其基类的成员函数派生类重写基类的虚函数时&#xff0c;可以添加 virtual 关键字&#xff0c;但不是必须这么做虚函…

爬虫基础之爬取某基金网站+数据分析

声明: 本案例仅供学习参考使用&#xff0c;任何不法的活动均与本作者无关 网站:天天基金网(1234567.com.cn) --首批独立基金销售机构-- 东方财富网旗下基金平台! 本案例所需要的模块: 1.requests 2.re(内置) 3.pandas 4.pyecharts 其他均需要 pip install 模块名 爬取步骤: …

RKNN_C++版本-YOLOV5

1.背景 为了实现低延时&#xff0c;所以开始看看C版本的rknn的使用&#xff0c;确实有不足的地方&#xff0c;请指正&#xff08;代码借鉴了rk官方的仓库文件&#xff09;。 2.基本的操作流程 1.读取模型初始化 // 设置基本信息 // 在postprocess.h文件中定义&#xff0c;详见…

Learning Vue 读书笔记 Chapter 2

2. Vue 基本工作原理 2.1 Virtual DOM 概念&#xff1a; DOM: DOM以内存中树状数据结构的形式&#xff0c;代表了网页上的HTML&#xff08;或XML&#xff09;文档内容。它充当了一个编程接口&#xff0c;将网页与实际的编程代码&#xff08;如JavaScript&#xff09;连接起来…

【C++高并发服务器WebServer】-7:共享内存

本文目录 一、共享内存1.1 shmget函数1.2 shmat1.3 shmdt1.4 shmctl1.5 ftok1.6 共享内存和内存映射的关联1.7 小demo 二、共享内存操作命令 一、共享内存 共享内存允许两个或者多个进程共享物理内存的同一块区域&#xff08;通常被称为段&#xff09;。由于一个共享内存段会称…

CrypTen——基于pytorch的隐私保护机器学习框架

目录 一、CrypTen概述 二、应用场景 三、CrypTen优势 四、CrypTen技术解析 1.基于pytorch的构建基础 2.核心密码学原语 3.加密模型训练流程 五、传统隐私保护技术与CrypTen的对比 1.传统隐私保护技术介绍 2.CrypTen与传统隐私保护技术的区别 六、CrypTen的环境配置…

ES6 简单练习笔记--变量申明

一、ES5 变量定义 1.在全局作用域中 this 其实就是window对象 <script>console.log(window this) </script>输出结果: true 2.在全局作用域中用var定义一个变量其实就相当于在window上定义了一个属性 例如: var name "孙悟空" 其实就相当于执行了 win…

Arduino大师练成手册 -- 控制 PN532 NFC 模块

要在 Arduino 上控制 PN532 NFC 模块&#xff0c;你可以按照以下步骤进行&#xff1a; 硬件连接 VCC&#xff1a;连接到 Arduino 的 3.3V 引脚。 GND&#xff1a;连接到 Arduino 的 GND 引脚。 SDA&#xff1a;连接到 Arduino 的 SDA 引脚&#xff08;通常是 A4&#xff09…

python——Django 框架

Django 框架 1、简介 Django 是用python语言写的开源web开发框架&#xff0c;并遵循MVC设计。 Django的**主要目的是简便、快速的开发数据库驱动的网站。**它强调代码复用&#xff0c;多个组件可以很方便的以"插件"形式服务于整个框架&#xff0c;Django有许多功能…

大模型正确调用方式

1、ollama 安装 curl -fsSL https://ollama.com/install.sh | sh 如果是AutoDl服务器&#xff0c;可以开启学术加速。 source /etc/network_turbo 本次使用腾讯云Cloud Studio&#xff0c;所以已经安装好了 Ollama 2、启动 ollama run 模型的名字 ollama serve # 开启服务 olla…