您的位置:首页 > 其它

uva 10465 Homer Simpson(完全背包)

2013-09-10 21:23 295 查看
题目连接: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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: