码迷,mamicode.com
首页 > 其他好文 > 详细

UVA劲歌金曲

时间:2019-08-26 00:08:11      阅读:67      评论:0      收藏:0      [点我收藏+]

标签:pac   for   01背包   std   freopen   fill   include   长度   scanf   

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劲歌金曲

标签:pac   for   01背包   std   freopen   fill   include   长度   scanf   

原文地址:https://www.cnblogs.com/coder-cjh/p/11409879.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!