UVA 12563 Jin Ge jin Qu [h] ao 劲歌金曲 (01背包)
每首只能唱一次,而且中间不能不唱歌,所以先把状态赋值为-1,以区别合法状态和非法状态,在唱歌曲目最多的条件下,离开时间应该尽量晚。
状态定义f[i][j]考虑前i首歌唱歌时间为j的最大唱歌曲目
#include<bits/stdc++.h> using namespace std; const int maxn = 55; const int maxt = 180*maxn+679; int f[maxt]; const int JinGe = 678; int main() { //freopen("in.txt","r",stdin); int T; scanf("%d",&T); int kas = 0; while(T--){ int n,t; scanf("%d%d",&n,&t); int k = 0; memset(f,-1,sizeof(int)*t); f[0] = 0; for(int i = 0; i < n; i++){ int V ; scanf("%d",&V); for(int j = t-1; j >= V; j--){ if(~f[j-V] && ( f[j] < f[j-V]+1 ) ){ f[j] = f[j-V]+1; if(f[j] > f[k] || ( f[j] == f[k] && k < j ) ){ k = j; } } } } printf("Case %d: %d %d\n",++kas,f[k]+1,k+JinGe); } return 0; }