zoukankan      html  css  js  c++  java
  • 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
    ",++kas,f[k]+1,k+JinGe);
    
        }
        return 0;
    }
  • 相关阅读:
    Matrix Power Series
    The Noisy Party(BUPT)
    cony
    又见Fibonacci数列
    回文字符串
    街区最短路径问题
    点的变换
    可恶的麦兜(北邮)
    Travel
    Swing实现Java代码编辑器实现关键词高亮显示
  • 原文地址:https://www.cnblogs.com/jerryRey/p/4726582.html
Copyright © 2011-2022 走看看