hdoj GTW likes gt 5596 (DP机智转换)好题

来源:互联网 发布:指南针软件 不断打电话 编辑:程序博客网 时间:2024/05/16 17:43

GTW likes gt

Accepts: 54
Submissions: 782
Time Limit: 2000/1000 MS (Java/Others)
Memory Limit: 131072/131072 K (Java/Others)
问题描述
从前,有nnn只萌萌的GT,他们分成了两组在一起玩游戏。他们会排列成一排,第iii只GT会随机得到一个能力值bib_ibi。在第iii秒的时候,第iii只GT可以消灭掉所有排在他前面的和他不是同一组的且能力值小于他的GT。为了使游戏更加有趣,GT的首领GTW会发功mmm次,第iii次发功的时间为cic_ici,则在第cic_ici秒结束后,b1,b2,...,bcib_1,b_2,...,b_{c_i}b1,b2,...,bci都会增加1。现在,GTW想知道在第nnn秒之后,会有几只GT存活下来。
输入描述
第一行只有一个整数T(T≤5)T(T\leq 5)T(T5),表示测试数据组数。第二行有两个整数n,mn,mn,m。表示GT的个数和GTW发功的次数。(1≤n≤50000,1≤m≤500001\leq n \leq 50000,1\leq m\leq 500001n50000,1m50000)第三到n+2n+2n+2行,每行有两个整数ai,bia_i,b_iai,bi,表示第iii只GT在哪个组和他的能力值 (0≤a[i]≤1,1≤b[i]≤106)(0\leq a[i]\leq 1,1\leq b[i]\leq 10^6)(0a[i]1,1b[i]106)n+3n+3n+3行到第n+m+2n+m+2n+m+2行,每行有一个整数cic_ici,表示GTW第iii次发功的时间。1≤c[i]≤n1\leq c[i]\leq n1c[i]n
输出描述
总共TTT行,第iii行表示第iii组数据中,GT存活的个数。
输入样例
14 30 31 20 31 1134
输出样例
3
Hint
111秒后 能力值为4 2 3 14\ 2\ 3\ 14 2 3 1222秒后 能力值为4 2 3 14\ 2\ 3\ 14 2 3 1333秒后 能力值为5 3 4 15\ 3\ 4\ 15 3 4 1,第222只GT被第333只GT消灭掉了第444秒后 能力值为6 4 5 26\ 4\ 5\ 26 4 5 2cic_ici并不是有序的
 
#include<stdio.h>#include<string.h>#include<algorithm>#define N 100010using namespace std;int a[N];struct zz{int zy;int nn;}q[N];int main(){int t;int n,m;scanf("%d",&t);while(t--){scanf("%d%d",&n,&m);for(int i=1;i<=n;i++)scanf("%d%d",&q[i].zy,&q[i].nn);memset(a,0,sizeof(a));for(int i=1;i<=m;i++){int x;scanf("%d",&x);a[x]++;}for(int i=1;i<=n;i++)a[i]+=a[i-1];int mm0=-0x3f3f3f;int mm1=mm0;int cnt=n;for(int i=n;i>=1;i--){int mm=q[i].zy;if(mm){if(q[i].nn-a[i-1]<mm0)cnt--;mm1=max(mm1,q[i].nn-a[i-1]);}else{if(q[i].nn-a[i-1]<mm1)cnt--;mm0=max(mm0,q[i].nn-a[i-1]);}}printf("%d\n",cnt);}return 0;}
//刚开始这样写的,果断超时。。
#include<stdio.h>#include<string.h>#include<algorithm>#define N 50010#define INF 0x3f3f3f3fusing namespace std;int b[N];int vis[N];struct zz{int zy;int nl;}q[N<<1],mm;int main(){int t,n,m;int i,j;int x,y,c;scanf("%d",&t);while(t--){memset(vis,0,sizeof(vis));memset(b,0,sizeof(b));scanf("%d%d",&n,&m);for(i=1;i<=n;i++)scanf("%d%d",&q[i].zy,&q[i].nl);for(i=1;i<=m;i++){scanf("%d",&b[i]);vis[b[i]]=1;}int cnt=n;for(i=1;i<=n;i++){if(q[i].nl!=INF){mm=q[i];for(j=1;j<i;j++){if(q[j].nl!=INF){if(q[j].zy!=mm.zy&&q[j].nl<mm.nl){cnt--;q[j].nl=INF;}}}if(vis[i])for(j=1;j<=i;j++)q[j].nl++;}}printf("%d\n",cnt);}return 0;}


0 0
原创粉丝点击