0-1背包问题

哎嗨我来了

前置知识:DP

DP

DP的推理建立在一个数组上

DP也是分一维二维的,一维DP也就是只有两个状态的DP,二维则有三个状态(如有物品个数、背包容量,价值),其中两个做被拆分的对象,一个做状态下的值

背包问题

上面给出的那篇文章举的那个栗子就是典型的0-1背包问题,具体的拆分步骤已经给出,这里想说的是,0-1背包问题实际上就是把一些有价值有体积(或重量)一个容量给定的背包内(也可以是一个类似背包的东西),求可以装的最大值。

这时候就可以用DP求解,先观察,他可以分成规模更小的问题,符合重叠子问题,至于最优子结构嘛......这个有点难证明,先放一放,他为什么没有后效性,别问我,我也不知道看上面给出的文章你就知道了。

有人就问了:"那么既然是动态规划,那肯定就比枚举要快,但是说了那么一大篇,我还不知道它是怎么推的呢?"别急别急,这就说。

动规有一个状态转移方程,这就是动态规划的核心,没它不行,其他代码只是浮云为了迎合题目要求做的一些加工而已,但是,状态转移方程也会变欧~最长不下降子序列有它的转移方程,最长公共子序列也有一个转移方程,同理,背包问题也有他的转移方程,而且,就算它是背包问题的转移方程,它也会根据不同的题目的条件摇身一变(当然不会变得太离谱),变成一个改装的核心。

那么背包问题的转移方程的改装也是建立在模板背包的转移方程的基础上的改装,所以模板还是要学习滴~

废话不多说了,先看看背包问题的"三元素":重量(背包重量),价值,物品个数,因为求的是价值,所以重量和物品个数做被分成子问题的对象,价值做状态下的值,不多说了,现在就上代码。

就知道你们想要这个

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n,m,dp[1001][1001],v[1001],h[1001];//dp[i][j]表示在前i个物品中选出一些装入容量为j的背包里可获得的物品最大值 
int main(){
	cin>>n>>m;
	for(int i=1;i<=m;i++){
		cin>>h[i]>>v[i];//输入 
	}
	for(int i=1;i<=m;i++){//枚举所有物品 
		for(int j=1;j<=n;j++){//枚举背包容量 
			if(h[i]<=j){//装得下的情况
				dp[i][j]=max(dp[i-1][j],dp[i-1][j-h[i]]+v[i]);//要么就装,要么就不装,不装的情况就是直接照搬上一个物品的最大值,装的话就是找到减去当前物品重量的背包的价值最大值加上当前物品的价值 
			}
			else dp[i][j]=dp[i-1][j];//装不下就只能照搬上一个物品的最大值 
		}
	}
	cout<<dp[m][n];
}
相关推荐
格图素书1 小时前
数学建模算法案例精讲500篇-【数学建模】DBSCAN聚类算法
算法·数据挖掘·聚类
DashVector2 小时前
向量检索服务 DashVector产品计费
数据库·数据仓库·人工智能·算法·向量检索
AI纪元故事会2 小时前
【计算机视觉目标检测算法对比:R-CNN、YOLO与SSD全面解析】
人工智能·算法·目标检测·计算机视觉
夏鹏今天学习了吗2 小时前
【LeetCode热题100(59/100)】分割回文串
算法·leetcode·深度优先
卡提西亚2 小时前
C++笔记-10-循环语句
c++·笔记·算法
还是码字踏实2 小时前
基础数据结构之数组的双指针技巧之对撞指针(两端向中间):三数之和(LeetCode 15 中等题)
数据结构·算法·leetcode·双指针·对撞指针
Coovally AI模型快速验证4 小时前
当视觉语言模型接收到相互矛盾的信息时,它会相信哪个信号?
人工智能·深度学习·算法·机器学习·目标跟踪·语言模型
电院工程师5 小时前
SIMON64/128算法Verilog流水线实现(附Python实现)
python·嵌入式硬件·算法·密码学
轮到我狗叫了5 小时前
力扣.84柱状图中最大矩形 力扣.134加油站牛客.abb(hard 动态规划+哈希表)牛客.哈夫曼编码
算法·leetcode·职场和发展
丛雨要玩游戏5 小时前
字符函数和字符串函数
c语言·开发语言·算法