开心的金明
题意:0-1背包经典题;
不多述,直接上代码:
【开心的金明】1.二维数组表示法:
#include
#include
#include
#include
using namespace std;
int dp[30][30005];
int main ()
{
int R,N;
int v,m;
scanf("%d%d",&R,&N);
for(int i=1;
i<=N;
i++){
scanf("%d%d",&v,&m);
for(int j=1;
j<=R;
j++){
dp[i][j]=(i==1?0:dp[i-1][j]);
if(j>=v)
dp[i][j]=max(dp[i][j],dp[i-1][j-v]+v*m);
}
}
printf("%d\n",dp[N][R]);
return 0;
}
2:一维数组表示法:
#include
#include
#include
#include
using namespace std;
int dp[30005];
int main ()
{
int R,N;
int v,m;
scanf("%d%d",&R,&N);
for(int i=1;
i<=N;
i++){
scanf("%d%d",&v,&m);
for(int j=R;
j>=v;
j--)
dp[j]=max(dp[j],dp[j-v]+v*m);
}
printf("%d\n",dp[R]);
return 0;
}
推荐阅读
- 热闹中的孤独
- JAVA(抽象类与接口的区别&重载与重写&内存泄漏)
- 放屁有这三个特征的,请注意啦!这说明你的身体毒素太多
- 一个人的旅行,三亚
- 布丽吉特,人生绝对的赢家
- 慢慢的美丽
- 尽力
- 一个小故事,我的思考。
- 家乡的那条小河
- 《真与假的困惑》???|《真与假的困惑》??? ——致良知是一种伟大的力量