栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

[动态规划]0/1背包问题(省空间复杂度)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

[动态规划]0/1背包问题(省空间复杂度)

0/1背包问题是动态规划中最为经典的题目。
有n个物品,已知各自的体积和价值,现有给定容量的背包,如何让背包里装入的物品具有最大的价值总和?
样例输入:
3 8
3 3
5 4
5 5
样例输出:
8

上一篇文章中用了二维数组,比较浪费空间复杂度,这里使用一维数组,思路与上一篇相同。(一维数组只保留最高价值)
由于用了一维数组,所以关键判别式应为
f[j] = max(f[j], f[j - w[i]] + c[i]);

代码如下:

#include 
using namespace std;
int w[1001],c[1001],f[1001];
int main(){
	int i,j,m,n;
	cin >> m >> n;
	for (i = 1; i <= n; i++){
		cin >> w[i] >> c[i];
	}
	for (i = 1; i <= n; i++){
		for (j = m; j >= 0; j--){
			if (j >= w[i]){
				f[j] = max(f[j], f[j - w[i]] + c[i]);
			}
		}
	}
	cout << f[m];
	return 0;
} 
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/330640.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号