EOJ-2112 WYI

http://acm.cs.ecnu.edu.cn/problem.php?problemid=2112

题意:给出时间上限,并给出每道题需要完成的时间以及得到的价值,求能得到的最大价值

与01背包不同的是,这题的时间最大10^9,即容量为这么多,不能直接对容量DP,

但发现每道题获得的价值有上限200,且n最大为100,就可以对价值进行DP,然后得到所有价值中时间小于等于给出最大时间的最大值

即 dp[i]为获得价值为i需要花费的最短时间,转移方程为dp[i]=min{dp[i],dp[i-V]+t}; 选出{max(i)|dp[i]<=tMax,0<=i<=Vmax}

 1 #include<map>
 2 #include<set>
 3 #include<list>
 4 #include<cmath>
 5 #include<ctime>
 6 #include<queue>
 7 #include<stack>
 8 #include<cctype>
 9 #include<cstdio>
10 #include<string>
11 #include<cstdlib>
12 #include<cstring>
13 #include<iostream>
14 #include<algorithm>
15 using namespace std;
16 const int maxn=105;
17 const int inf=0x3f3f3f3f;
18 int t[maxn],v[maxn];
19 int dp[200*maxn];
20 int main(){
21     int T;
22     cin>>T;
23     while(T--){
24         int n,l;
25         scanf("%d%d",&n,&l);
26         int Max=0;
27         for(int i=1;i<=n;i++){
28             scanf("%d%d",t+i,v+i);
29             Max+=v[i];                        //小优化
30         }
31         for(int i=1;i<=Max;i++)                //获得0价值时需要0的时间,其他的就姑且设为最大值(因为要取min)
32             dp[i]=inf;    
33         dp[0]=0;
34         for(int i=1;i<=n;i++)
35             for(int j=Max;j>=v[i];j--){
36                 dp[j]=min(dp[j-v[i]]+t[i],dp[j]);
37             }
38         int ans=0;
39         for(int i=0;i<=Max;i++){
40             if(dp[i]<=l)                    //选取其中花时间小于等于给定时间中 价值最高的
41                 ans=max(ans,i);
42         }
43         printf("%d\n",ans);
44     }
45     return 0;
46 }
View Code

 

 

posted on 2013-06-30 03:00  KimKyeYu  阅读(232)  评论(0编辑  收藏  举报

导航