首页 > 其他 > 详细

HDU 1171 Big event in hdu

时间:2014-08-06 22:51:52      阅读:390      评论:0      收藏:0      [点我收藏+]

这题 就是 简单的 多重背包应用..本来以为可以很快地写出来;

WA了无数次就是没找出哪里错了(有太自信的缘故);

百度了半天别人的代码,对照了半小时...说实话都要吐血了....;

终于发现了哪里错了;

教训,教训啊;再简单的题目也要慢慢来,不能太自信;

 1 #include<iostream>
 2 #define maxn 2000000
 3 int v[1005],c[1005],dp[maxn];
 4 #define max(a,b) (a>b?a:b)
 5 using namespace std;
 6 int main()
 7 {
 8     //freopen("1171.txt","r",stdin);
 9     int n,i,j,sum;
10     while(~scanf("%d",&n))
11     {
12         memset(v,0,sizeof(v));
13         memset(c,0,sizeof(c));
14         sum=0;
15         if(n<=0) break;
16         for(i=1;i<=n;i++)
17         {
18             scanf("%d%d",v+i,c+i);
19             sum+=v[i]*c[i];
20         }
21         memset(dp,0,sizeof(dp));
22         int value=sum/2;
23         for(i=1;i<=n;i++)
24         {
25             if(v[i]*c[i]>=value)
26             {
27                 for(j=v[i];j<=value;j++)
28                     dp[j]=max(dp[j],dp[j-v[i]]+v[i]);
29                 continue;
30             }
31             int k=1;
32             while(k<c[i])
33             {
34                 for(j=value;j>=v[i]*k;j--)
35                     dp[j]=max(dp[j],dp[j-k*v[i]]+k*v[i]);
36                 c[i]-=k;
37                 k+=k;
38             }
39             for(j=value;j>=v[i]*c[i];j--)
40                 dp[j]=max(dp[j],dp[j-c[i]*v[i]]+v[i]*c[i]);
41         }
42         
43         printf("%d %d\n",sum-dp[value],dp[value]);
44     }
45     return 0;
46 }

 

HDU 1171 Big event in hdu,布布扣,bubuko.com

HDU 1171 Big event in hdu

原文:http://www.cnblogs.com/xiaoniuniu/p/3895787.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!