UVA劲歌金曲
Posted coder-cjh
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了UVA劲歌金曲相关的知识,希望对你有一定的参考价值。
Solution
很容易想到这是一个01背包,因为还要留时间,就先把时间的1扣掉,之后再加上劲歌金曲的678秒,其它的细节注意一下就好了。
Code
#include<bits/stdc++.h> using namespace std; int n,t,w[100005],a[100005],f[100005]; int main() freopen("a.in","r",stdin); int T,cnt=0; scanf("%d",&T); while(T--) scanf("%d%d",&n,&t); --t; fill(f,f+t+1,0);//记得要+1否则清不到f[t] fill(a,a+t+1,0); for(int i=1;i<=n;i++) scanf("%d",&w[i]); for(int i=1;i<=n;i++) for(int j=t;j>=w[i];j--) if(f[j]<f[j-w[i]]+1) f[j]=f[j-w[i]]+1,a[j]=a[j-w[i]]+w[i];//因为还要使总长度最长 else if(f[j]==f[j-w[i]]+1&&a[j]<a[j-w[i]]+w[i])//同时记录总长度 a[j]=a[j-w[i]]+w[i]; printf("Case %d: %d %d\n",++cnt,f[t]+1,a[t]+678);//最后+1再+678
以上是关于UVA劲歌金曲的主要内容,如果未能解决你的问题,请参考以下文章
UVA12563Jin Ge Jin Qu hao(01背包)