c++【提高】简单背包问题

时间限制 : 1 秒

内存限制 : 128 MB

有一个背包能装的重量 maxw (正整数,0≤maxw≤20000),同时有 n 件物品(1≤n≤100),每件物品有一个重量 w_i(正整数)和一个价值 p_i(正整数)。要求从这 n 件物品中任取若干件装入背包内,使背包的物品价值最大。

输入

第 1 行:背包最大载重 maxw,物品总数 n ;

第 2 行到第 n+1 行:每个物品的重量和价值;

输出

一个数字即背包内物品最大价值;

样例
输入
复制代码
10 3
4 5
3 4
6 9
输出
复制代码
14
来源

动态规划 背包问题

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int v,n;
int w[105],p[105];
int dp[105][20005];
int main()
{
	cin>>v>>n;
	for(int i=1;i<=n;i++)
	{
		cin>>w[i]>>p[i];
	}
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=v;j++)
		{
			if(w[i]<=j)
			{
				dp[i][j]=max(dp[i-1][j],dp[i-1][j-w[i]]+p[i]);
			}
			else
			{
				dp[i][j]=dp[i-1][j];
				
			}
		}
	}
	cout<<dp[n][v];
	return 0;
}

优化后:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int v,n;
int w[105],p[105];
int dp[20005];
int main()
{
	cin>>v>>n;
	for(int i=1;i<=n;i++)
	{
		cin>>w[i]>>p[i];
	}
	for(int i=1;i<=n;i++)
	{
		for(int j=v;j>=w[i];j--)
		{
			dp[j]=max(dp[j],dp[j-w[i]]+p[i]);
		}
	}
	cout<<dp[v];
	return 0;
}

​
相关推荐
AI进化营-智能译站18 小时前
ROS2 C++开发系列17-多线程驱动多传感器|chrono高精度计时实现机器人同步控制
java·c++·ai·机器人
天若有情67321 小时前
程序员原创|借鉴JS事件冒泡,根治电脑文件混乱的“冒泡整理法”
开发语言·javascript·windows·ecmascript·电脑·办公·日常
墨染千千秋21 小时前
C++函数的使用以及主函数
c++
特种加菲猫1 天前
继承,一场跨越时空的对话
开发语言·c++
WBluuue1 天前
Codeforces 1093 Div2(ABCD1D2)
c++·算法
玩转单片机与嵌入式1 天前
玩转边缘AI(TInyML):需要掌握的C++知识汇总!
开发语言·c++·人工智能
历程里程碑1 天前
4 Git远程协作:从零开始,玩转仓库关联与代码同步(带实操代码讲解)
大数据·c++·git·elasticsearch·搜索引擎·gitee·github
茉莉玫瑰花茶1 天前
Qt 信号与槽 [ 1 ]
开发语言·数据库·qt
汉克老师1 天前
GESP5级C++考试语法知识(贪心算法(一)课堂例题精讲)
c++·贪心算法·gesp5级·gesp五级·贪心规律