syhd142  
日历
<2024年11月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567
统计
  • 随笔 - 23
  • 文章 - 122
  • 评论 - 31
  • 引用 - 0

导航

常用链接

留言簿(2)

随笔档案(23)

文章分类(270)

文章档案(122)

我的豆瓣

搜索

  •  

最新评论

阅读排行榜

评论排行榜

 
完全背包问题,一个物品可以无限次的使用。还有需要注意的就是该题要求恰好装满背包时的最小值,初始化的时候除了f[0]=0之外,其余的为负无穷。
#include <stdio.h>
#include 
<string.h>

#define N 10005
#define INF 2139062144
#define MAX(a, b) (a > b ? a : b)

int c[N], w[N], f[N];

int main()
{
    
int t, E, F, v, n;
    scanf(
"%d"&t);
    
while(t--)
    {
        scanf(
"%d %d"&E, &F);
        v 
= F - E;
        scanf(
"%d"&n);
        
for(int i = 0; i < n; i++)
        {
            scanf(
"%d %d"&w[i], &c[i]);
            w[i] 
= -w[i];
        }
        
        memset(f, 
128sizeof(f));
        f[
0= 0;
        
for(int i = 0; i < n; i++)
        {
            
for(int j = c[i]; j <= v; j++)
            {
                f[j] 
= MAX(f[j], f[j - c[i]] + w[i]);
            }
        }
        
        
if(f[v] > -INF)printf("The minimum amount of money in the piggy-bank is %d.\n"-f[v]);
        
else puts("This is impossible.");
    }
    
return 0;
}
posted on 2010-07-25 11:39 Fucker 阅读(179) 评论(0)  编辑 收藏 引用 所属分类: ACM/ICPCDP

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


 
Copyright © Fucker Powered by: 博客园 模板提供:沪江博客