18290 校赛排名2
时间限制:1000MS 内存限制:65535K
提交次数:0 通过次数:0
题型: 编程题 语言: G++;GCC;VC
Description
下面是校赛的排名规则: 比赛期间,提交代码后,系统会返回正确或错误等结果。最后的获胜者为正确解答题目最多,如果同题数则总用时最少的队伍。 每道试题的时间花费将从竞赛开始到试题提交并且被判定为正确为止,其间每一次提交运行结果被判错误的话将被加罚20分钟时间, 未正确解答的试题不记时,如果已经返回正确的题目再重复提交则不影响结果。 例如:A、B两队都正确完成两道题目,其中A队提交这两题的时间分别是比赛开始后60分钟和165分钟,B队为80分钟和130分钟, 但B队第一个题提交了2次才通过。这样A队的总用时为60+165=225而B队为(80+20)+130=230,所以A队以总用时少而获胜。 现在给出裁判机上面所有队伍的提交时间(分钟数)和返回结果,需要你编程输出当前比赛的排行榜。 注:0题的队伍不需要输出
输入格式
每行一个评判结果,格式为:时间(第几分钟提交的)+半角空格+队名+半角空格+题号+半角空格+评判结果(0通过,其它为出错) 题号由大写A字符开始,第2题是B,依次类推,最多不超过15题 所有评判结果已经按时间排序好
输出格式
输出排名,一行一个,格式为队名+半角空格+通过题数+半角空格+罚时 注:0题的队伍不需要输出 测试数据中,没有同题且同罚时的情况
输入样例
2 abc A 4 5 abc B 0 6 def A 0 10 abc A 0 13 xyx A 4 20 def B 5
输出样例
abc 2 35 def 1 6
#include <iostream>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <algorithm>
#include <cstring>
using namespace std;
typedef struct Team
{
long long t1;
char name[1000];
long long have_solved[1000];
long long solved;
long long submit[10000];
} Team;
Team T[1000];
char Name[1000];
long long t;
char num;
char result[1000];
int TeamNum=0;
int cmp(Team t2,Team t3)
{
if(t2.solved>t3.solved) return 1;
else if(t2.solved==t3.solved&&t2.t1<t3.t1) return 1;
else if(t2.solved==t3.solved&&t2.t1==t3.t1&&strcmp(t2.name,t3.name)<0) return 1;
else return 0;
}
int main()
{
long long i,j;
while(scanf("%lld %s %c %s",&t,Name,&num,result)>0)
{
for(i=0; i<TeamNum; i++)
{
if(strcmp(T[i].name,Name)==0) break;
}
if(i==TeamNum)
{
for(j=0; j<strlen(Name); j++) T[i].name[j]=Name[j];
T[i].name[j]='\0';
T[i].t1=0;
T[i].solved=0;
for(j=0; j<15; j++)
{
T[i].have_solved[j]=0;
T[i].submit[j]=0;
}
TeamNum++;
}
if(T[i].have_solved[num-'A']==0)
{
T[i].submit[num-'A']++;
if(strcmp(result,"0")==0)
{
T[i].have_solved[num-'A']=1;
T[i].solved++;
T[i].t1+=((T[i].submit[num-'A']-1)*20+t);
}
}
}
sort(T,T+TeamNum,cmp);
for(j=0; j<TeamNum; j++)
{
if(T[j].solved==0) break;
printf("%s %lld %lld\n",T[j].name,T[j].solved,T[j].t1);
}
}