uva 10465 Homer Simpson(完全双肩包)

uva 10465 Homer Simpson(完全背包)

题目连接:10465 - Homer Simpson


题目大意:有两种汉堡包, 给出吃汉堡的时间, 再给出总的时间, 尽量不浪费给出的时间,输出能最多吃的汉堡个数, 如果一定需要浪费时间, 输出浪费时间最少的时刻内能吃的最多汉堡个数, 并再后面输出浪费掉的时间。


解题思路:因为汉堡可以无限制的使用, 所以相当于是完全背包问题,dp[i]就是代表在i分钟之内最多能吃多少汉堡(时间完全使用完), dp[i] = 0说明该时间是有浪费的。


#include <stdio.h>
#include <string.h>
const int N = 10005;

int a, b, sum, dp[N * 2];

void solve() {
    memset(dp, 0, sizeof(dp));
    dp[a] = 1;
    for (int i = 0; i < N; i++)
       if (dp[i] && dp[i] + 1 > dp[i + a])
	    dp[i + a] = dp[i] + 1;	   
    dp[b] = 1;
    for (int i = 0; i < N; i++)
	if(dp[i] && dp[i] + 1 > dp[i + b])
	    dp[i + b] = dp[i] + 1;
}

int main() {
    while (scanf("%d%d%d", &a, &b, &sum) == 3) {
	int flag = 1;
	solve();
	for (int i = 0; i <= sum; i++)
	    if (dp[sum - i]) {
		printf("%d", dp[sum - i]);
		if (i)
		    printf(" %d", i);
		printf("\n");
		flag = 0;
		break;
	    }
	if (flag)
	    printf("0 %d\n", sum);
    }
    return 0;
}