C++求解01背包问题

描述

你是一个探险家,有一天,你在某个神秘的洞穴中发现N件珠宝,每件珠宝上写着其重量wi和价值vi。由于你发现得比较晚,这个地方随时会出现塌陷等事故,这事你就得考虑把一部分珠宝放入你的随身背包中带走,以便不虚此行。但是,由于你个子吃紧,最多可以带走的珠宝总重量不超过W,那你将如何挑选呢?

输入格式

第一行:N M,表示N件珠宝,你的承重能力W

接下来是N行,每行输入wi vi,表示第i件珠宝的单重和单价

输出格式

一行,表示你能带走珠宝的最佳方案所能达到的价值

示例

输入

【3件珠宝,10总承重】

【珠宝重量[9,5,5]】 【珠宝价值[9,5,5]】

cpp 复制代码
3 10
9 9
5 5
3 5

输出

【应该挑第2件和第3件珠宝带走,总重量8小于自身承重,总价值10】

cpp 复制代码
10

代码

cpp 复制代码
#include<iostream>
#include<vector>
#include<cmath>
using namespace std;
int main() {
	int N,W;
	cin>>N>>W;

	vector<int> w(N+1,0);
	vector<int> v(N+1,0);
	for(int i=1; i<=N; i++) {
		cin>>w[i]>>v[i];
	}

	vector<vector<int> > res(N+1,vector<int>(W+1,0));
	for(int i=1; i<=N; i++) {
		for(int j=0; j<=W; j++) {
			if(j<w[i]) {
				res[i][j]=res[i-1][j];
			} else {
				res[i][j]=max(res[i-1][j],res[i-1][j-w[i]]+v[i]);
			}
		}
	}

	cout<<res[N][W]<<endl;
	return 0;
}

运行结果

cpp 复制代码
3 10
9 9
5 5
3 5
10

--------------------------------
Process exited after 6.262 seconds with return value 0
请按任意键继续. . .

解析

把二维数组res当做求解空间 ,第一维度表示已经对前几个珠宝做完决定

第二维度表示已经使用背包载量,使用动态规划算法进行求解。

对于第i件珠宝,如果剩余载量不足,则跟这件珠宝不在没有区别,于是总价不变

但当剩余载量足够,则需要比较载入与否的总价,择优选取。

刚遇到的小伙伴可能难以理解,不要急躁,多看几遍就理解了。

由于举例的数字比较小,大家可以搞个二维表格表示res来帮助理解。

相关推荐
luckys.one1 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
TomCode先生2 小时前
c#动态树形表达式详解
开发语言·c#
高-老师2 小时前
基于R语言的物种气候生态位动态量化与分布特征模拟
开发语言·r语言·物种气候
大翻哥哥2 小时前
Python 2025:量化金融与智能交易的新纪元
开发语言·python·金融
~|Bernard|2 小时前
在 PyCharm 里怎么“点鼠标”完成指令同样的运行操作
算法·conda
战术摸鱼大师3 小时前
电机控制(四)-级联PID控制器与参数整定(MATLAB&Simulink)
算法·matlab·运动控制·电机控制
Christo33 小时前
TFS-2018《On the convergence of the sparse possibilistic c-means algorithm》
人工智能·算法·机器学习·数据挖掘
weixin_437830943 小时前
使用冰狐智能辅助实现图形列表自动点击:OCR与HID技术详解
开发语言·javascript·ocr
鹿鹿学长4 小时前
2025年全国大学生数学建模竞赛(C题) 建模解析|婴儿染色体数学建模|小鹿学长带队指引全代码文章与思路
c语言·开发语言·数学建模
好家伙VCC4 小时前
数学建模模型 全网最全 数学建模常见算法汇总 含代码分析讲解
大数据·嵌入式硬件·算法·数学建模