HDU 2546 —— 饭卡 01背包入门

http://acm.hdu.edu.cn/showproblem.php?pid=2546


注意点:1、若一开始钱就少于5元,就直接输出钱数,因为什么都买不了;2、将余额先减去5元,这5元我们用来买最贵的;

#include
#include
#include
using namespace std;
const int maxn = 1100;
int n, m;
int dp[maxn];
int a[maxn];

int main()
{
	while(~scanf("%d", &n))
	{
		memset(dp, 0, sizeof dp);
		if(n == 0)	break;
		for(int i = 1;i<=n;i++)
		scanf("%d", &a[i]);
		sort(a+1, a+n+1);
		scanf("%d", &m);
		if(m < 5)
		{
			printf("%d\n", m);
			continue;
		}
		m -= 5;
		for(int i = 1;i=a[i];j--)
			dp[j] = max(dp[j], dp[j-a[i]]+a[i]);
		}
		int ans = m + 5 - (dp[m]+a[n]);
		printf("%d\n", ans);
	}
	return 0;
}


你可能感兴趣的:(=====动态规划=====,背包)