2018年全国多校算法寒假训练营练习比赛(第二场)B_01背包

2018年全国多校算法寒假训练营练习比赛(第二场)B

只写了四题,220名开外,,,菜到泣不成声
可能是评测机的bug,比赛结束还是4题,写完博客一刷新,就变成五题了,排名瞬间130+
赛后补题中
[题目链接](https://www.nowcoder.com/acm/contest/74/B)

题目描述
	Taotao的电脑带不动绝地求生,所以taotao只能去玩pc版的荒野行动了,和绝地求生一样,游戏人物本身可以携带一定重量m的物品,装备背包之后可以多携带h(h为0代表没有装备背包)重量的东西。玩了几天taotao发现了一个BUG,当装备背包之后,如果可携带重量没有满,就可以拿一个任意重的东西。(解释看样例)有一天taotao空降到了一个奇怪的岛上,岛上有n件装备,每个装备都有重量Wi和威力值Vi,但taotao不认识这些装备,所以他来求助你,挑选威力最大的装备,帮助他吃鸡。
输入描述:
	本题有多组输入(小于10),当n=0时结束输入。第一行输入n,m,h。n,m,h为整数,并且0<=n,m,h<=100,接下来n行,每行输入第i个物品的物品的重量Wi和威力值Vi。0<=Wi,Vi<=100.
输出描述:
输出最大威力值,每组输出一行。
示例1
	输入
	3 3 3
	2 3
	3 2
	2 3
	0
	输出
	8
说明
	可携带的总重量为6,当拿了前两件装备,此时容量为5/6,还可以再拿第三件物品。
解题思路
	当h==0时,典型的01背包
	当h!=0时,枚举最后一个放进去的装备,剩下的还是01背包
	[背包详解]()
AC代码
#include<iostream>
#include<algorithm>
#include<string.h>
using namespace std;
int n, m, h;
int w[504], v[504], dp[504];
int main()
{
	while (cin>>n&&n!=0)
	{
		cin >> m >> h;
		for (int i = 1; i <= n; i++)
		{
			cin>>w[i]>>v[i];
		}
		int ans = 0;
		if (h == 0)
		{
			memset(dp, 0, sizeof(dp));
			for (int i = 1; i <= n; i++)
			{
				for (int j = m; j >= w[i]; j--)
				{
					dp[j] = max(dp[j], dp[j - w[i]] + v[i]);
				}
			}
			ans = dp[m];
		}
		else
		{
			for (int k = 1; k <= n; k++)
			{
				memset(dp, 0, sizeof(dp));
				for (int i = 1; i <= n; i++)
				{
					if (i == k)  continue;
					for (int j = m + h - 1; j >= w[i]; j--)
					{
						dp[j] = max(dp[j], dp[j - w[i]] + v[i]);
					}
				}
				ans = max(ans, dp[m + h - 1] + v[k]);
			}

		}
		cout << ans << endl;

	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值