UVA - 12563
程序员文章站
2022-06-01 22:52:53
...
这题是求两个状态的分先后级别的最优解的0/1背包变形。
参考博客:
https://www.cnblogs.com/shi2015/p/4661971.html
https://blog.csdn.net/u013480600/article/details/40376143
说几个细节点:
(1)
0/1背包里面没有这个判断条件,是因为要满足:
这个要求。如果j==T[i]的时候,会有dp[0]==0,所以就不能进入这个条件里面,所以要特意判断一下。
因为如果不是这种情况,dp[i]==0即代表时间i内不能刚刚好唱完dp[i]首歌。
(2)
1处一定要判断maxn 是否为0,因为如果maxn是0那么在表示刚刚好唱完i首歌的dp[i]也满足条件了,就会不满足
这个条件。(maxn=0表示 在给定时间内无法唱完任何一首歌)
2处一定要是最小的一首歌的时间,而不能是1,因为会崩。所以要多一步排序。
(3)
这里数组不能开太大(竟然返回tle。。。无语)虽然题目中说的t<=1e9,但是这里1e7也可以过,可能是数据太弱????
代码:
//G
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define MAXN 60
#define MAXN2 10000000
int T[MAXN];
int dp[MAXN2];
int main()
{
int i,j;
int kase,casenum;
int n;
int t;
int ans;
int maxn;
scanf("%d",&casenum);
kase=0;
while(casenum--)
{
scanf("%d%d",&n,&t);
memset(T,0,sizeof(T));
for(i=1;i<=n;i++)
scanf("%d",&T[i]);
memset(dp,0,sizeof(dp));
maxn=0;
for(i=1;i<=n;i++)
{
for(j=t-1;j>=T[i];j--)
{
if(dp[j-T[i]]>0||j==T[i])
{
dp[j]=max(dp[j],dp[j-T[i]]+1);
maxn=max(maxn,dp[j]);
}
}
}
ans=0;
sort(T+1,T+1+n);
if(maxn)
{
for(i=t-1;i>=T[1];i--)
{
if(dp[i]==maxn)
{
ans=maxn;
break;
}
}
}
else
ans=i=0;
ans++;
i+=678;
printf("Case %d: %d %d\n",++kase,ans,i);
}
return 0;
}
上一篇: 滑动窗口-滑动窗口中的最大值
推荐阅读
-
团体队列 UVA540 Team Queue
-
丑数(Ugly Numbers, UVa 136)
-
破损的键盘(悲剧文本)(Broken Keyboard(a.k.a. Beiju Text),Uva 11988)
-
集合栈计算机(The SetStack Computer, ACM/ICPC NWERC 2006,Uva12096)
-
唯一的雪花(Unique snowflakes,UVa 11572)滑动窗口+set
-
[UVA - 11584] Partitioning by Palindromes dp预处理
-
UVA227-Puzzle
-
UVA 442 Matrix Chain Multiplication ( stack 应用)
-
UVA 136 - Ugly Numbers(优先队列 + 集合)
-
(UVa 136) Ugly Numbers(丑数的生成+整数分解定理+优先队列)