UVA 12563 "Jin Ge Jin Qu hao" (背包)

传送门

debug了好一会,突然发现,输出错了,emmm.........

明天再写debug历程

贴身ac代码先

 1 #include<bits/stdc++.h>
 2 #include<cstdio>
 3 #include<cstring>
 4 using namespace std;
 5 #define memF(a,b,n) for(int i=0;i <= n;a[i++]=b);
 6 const int maxn=1e5+50;
 7
 8 int n,T;
 9 int t[60];
10 int dp[maxn];
11
12 void Solve()
13 {
14     memF(dp,-1,T);
15     dp[0]=0;
16     for(int i=1;i <= n;++i)
17     {
18         for(int j=T-1;j >= t[i];--j)
19         {
20             if(dp[j-t[i]] != -1)
21                 dp[j]=max(dp[j],dp[j-t[i]]+1);
22         }
23     }
24     int ans=*max_element(dp,dp+T-1);
25     for(int i=T-1;i >= 0;--i)
26         if(dp[i] == ans)
27         {
28             printf("%d %d\n",dp[i]+1,i+678);
29             return ;
30         }
31 }
32 int main()
33 {
34     int test;
35     scanf("%d",&test);
36     for(int kase=1;kase <= test;++kase)
37     {
38         scanf("%d%d",&n,&T);
39         for(int i=1;i <= n;++i)
40             scanf("%d",t+i);
41
42         printf("Case %d: ",kase);
43         Solve();
44     }
45     return 0;
46 }

原文地址:https://www.cnblogs.com/violet-acmer/p/10961558.html

时间: 2024-12-17 10:43:33

UVA 12563 "Jin Ge Jin Qu hao" (背包)的相关文章

UVA 12563 Jin Ge Jin Qu hao 01背包变形

基本的01背包,更新的时候保持背包里每一个元素的num最大然后time尽量长 CSDN也支持makedown了试一下 12563 Jin Ge Jin Qu hao (If you smiled when you see the title, this problem is for you ^_^) For those who don't know KTV, see: http://en.wikipedia.org/wiki/Karaoke_box There is one very popul

uva 12563 - Jin Ge Jin Qu hao(动态规划~劲!歌!金!曲!)

错的我真是无语...还是状态的把握不准确.. 起始状态转移方程是很重要,但是只推出了方程是不够的 对边界状态的处理,对特殊状态的处理,这些都很重要,错了任何一个小地方,都会导致WA.... 细节!更清晰的思路,更全面的考虑! #include<cstdio> #include<cstring> #include<algorithm> using namespace std; int n,t; int v[55]; int d[55][10000]; int path[5

UVA Jin Ge Jin Qu hao 12563

Jin Ge Jin Qu hao (If you smiled when you see the title, this problem is for you ^_^) For those who don’t know KTV, see: http://en.wikipedia.org/wiki/Karaoke_box There is one very popular song called Jin Ge Jin Qu(). It is a mix of 37 songs, and is e

12563 - Jin Ge Jin Qu hao——[DP递推]

(If you smiled when you see the title, this problem is for you ^_^) For those who don’t know KTV, see: http://en.wikipedia.org/wiki/Karaoke_box There is one very popular song called Jin Ge Jin Qu(). It is a mix of 37 songs, and is extremely long (11

UVA 12563 Jin Ge Jin Qu hao(01背包变形:两个背包内容)

题意: KTV里面有n首歌曲你可以选择,每首歌曲的时长都给出了. 对于每首歌曲,你最多只能唱1遍. 现在给你一个时间限制t (t<=10^9) , 问你在最多t-1秒的时间内可以唱多少首歌曲num , 且最长唱歌时间是多少time (time必须<=t-1) ? 最终输出num+1 和 time+678 即可. 注意: 你需要优先让歌曲数目最大的情况下,再去选择总时长最长的. //0 KB 39 ms #include<cstdio> #include<cstring>

UVa 12563 (01背包) Jin Ge Jin Qu hao

如此水的01背包,居然让我WA了七次. 开始理解错题意了,弄反了主次关系.总曲目最多是大前提,其次才是歌曲总时间最长. 题意: 在KTV房间里还剩t秒的时间,可以从n首喜爱的歌里面选出若干首(每首歌只能唱一次且如果唱就必须唱完),然后剩下至少1秒的时间来唱那首长678秒的歌曲. 总曲目最多的前提下,尽量使歌曲总时间最长. 分析: 所给时间为t,在t-1秒内进行01背包,num[i]来记录剩余时间为 i 时能长的最多曲目,如果曲目相同还要记录最长时间. 1 //#define LOCAL 2 #i

UVa 12563 Jin Ge Jin Qu hao【01背包】

题意:给出t秒时间,n首歌分别的时间a[i],还给出一首长度为678的必须唱的劲歌金曲,问最多能够唱多少首歌(只要最后时间还剩余一秒,都可以将劲歌金曲唱完) 用dp[i]代表花费i时间时唱的歌的最大数量 背包容量即为给出的总时间t-1(留一秒钟唱劲歌金曲) ,每首歌的代价为a[i], 然后状态转移方程为 dp[j]=max(dp[j],dp[j-a[i]]+1); 自己写的时候,一直一直wa 后来看了lrj的代码,发现是初始化不对, 改掉初始化就对了= = 可是为什么要这样初始化呢= = 后来才

UVA - 12563 Jin Ge Jin Qu hao (01背包变形)

此题应该注意两个点,首先背包容量应该缩减为t-1,因为最长的歌不超过三分钟,而劲歌金曲有678s,所以肯定要留出这个时间来.其次注意优先级,保证唱的歌曲数目最多,在此前提下尽可能的延长时间. 处理方法:开创结构体,在歌曲数目相等的时候,选取最长时间. 注意:注意t的大小,t完全没有必要计算那么大的数据. 代码如下: #include<iostream> #include<cstdio> #include<cstring> #include<algorithm>

UVa 12563 Jin Ge Jin Qu hao(01背包)

题意  你在KTV还剩t秒钟的时间  你需要在n首歌中选择尽量多的歌使得歌的数量最多的前提下剩下的时间最小 至少要留一秒给劲歌金曲  所以是一个容量为t-1的01背包   d[i][j]表示恰用j秒时间在前i首歌中最多唱多少首  每个状态有两种选择 唱或不唱第i首歌 所以有转移方程d[i][j]=max(d[i-1][j],d[i-1][j-c[i]]+1) #include <bits/stdc++.h> using namespace std; const int N = 55, M =

UVA - 12563 Jin Ge Jin Qu hao (01背包)

首先这题的题意要先读懂,而不是一看到01背包的问题就开始敲. 题目大意: 如果问一个麦霸:"你在KTV里面必唱的歌曲有那些",得到的答案可能会包含古巨基的<劲歌金曲>,一般来说KTV不会在时间到的时候把正在唱的歌给切掉,而是会等它放完,例如还有15秒时再唱一首2分钟的歌,则实际上多唱了105秒.但是唱"神曲"<劲歌金曲>则相当于多唱了663秒. 现在要求你在唱的歌曲的曲数尽量多的情况下,唱的时间尽量长. 思路: 01背包的思路,每次记录下每个