处女座与cf 模拟

题目:

链接:https://ac.nowcoder.com/acm/contest/327/B
来源:牛客网
 

众所周知,处女座经常通过打cf来调节自己的心情。今天处女座又参加了一场cf的比赛,他知道了所有的提交记录,他想知道自己的得分和排在第几名。你知道处女座的cf账号是cnz

 

Codeforces规则如下:

1.       比赛一共2小时

2.       比赛有5题,A题500分,B题1000分,C题1500分,D题2000分,E题2500分。

3.       得分规则如下:

在第0分钟完成某一题可以得到全部的分数,每过一分钟每题的分值会衰减1/250,比如在第3分钟完成A题,能够得到500-2*3=494分

4.       如果一道题是的返回结果WA或者TLE被称为错误的提交,CE视为无效的提交,AC,WA和TLE 都视为有效的提交。如果一道题你最后通过了,你会得到这道题衰减之后的分值再减去你错误提交次数*50,就是每次错误的提交会有50分的罚时。

5.       如果你通过了一道题,你的得分不会低于该题分值的30%。比如你在第50分钟通过了A,你有7次错误的提交,你的得分为max(500*0.3,500-2*50(得分衰减)-7*50(错误提交的罚时))=150分。

6.       由于hack机制的存在,你每进行一次提交,对于这一题之前的有效提交(AC,WA,TLE)都视为错误的提交。

7.       一个人只有提交(AC,WA,TLE,CE)过代码,才被视为参加比赛。

 

处女座又了解到一些信息:

本场比赛没有任何选手hack别人,并且没有任何的提交fst(即只要是某题的最后一次提交通过,就视为通过这道题)

输入:
第一行两个整数n和m,n为报名比赛的人数,m为提交的个数
接下来n行,每行一个字符串,表示报名比赛的人的昵称。(字符串只包含小写字母,且长度小于20)
接下来m行,每行的格式为Time,Submiter,Problem,Verdict。
Time为提交的时间,是1到120中的一个正整数(包含1和120),保证Time按顺序给出
Submiter为提交者昵称
Problem为题目名称,是’A’,’B’,’C’,’D’,’E’中的一个字母。
Verdict为返回的结果,为”AC”,”WA”,”TLE”,”CE”中的一个。
2<=n<=500

1<=m<=10000

输出:

如果处女座参加了比赛,输出两行:
第一行为处女座的得分
第二行格式x/y,其中x为处女座的排名,y为参加比赛的总人数。如果分数相同那么排名并列。
如果处女座没有参加比赛,输出”-1”

样例输入:
3 7
cnz
cuber
moon
3 cnz A AC
5 cuber A AC
6 cnz B CE
10 cuber C AC
20 cnz B AC
30 cuber D TLE
100 cnz E AC

样例输出:

2914
1/2

直接模拟,需要考虑的是输入的是人名,怎样进行每一个人的操作,这里用到了map,用map给每个人标号。

AC代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <map>
using namespace std;
const int maxn=1e4+5;
int a[maxn][maxn];//每个人每道题的分数
int b[maxn][maxn];//每个人每道题提交的次数
int sum[maxn];//每个人的总分
int vis[maxn];//标记数组
map<string,int>ch;
int dis[5]={500,1000,1500,2000,2500};//初始化每道题的分数
int main()
{
   int n,m;
    scanf("%d%d",&n,&m);
    for(int i=0;i<n;i++)
    {
        string s;
        cin>>s;
        ch[s]=i;//给每个人名标号
    }
    for(int i=0;i<m;i++)
    {
        int tim;
        string sub,pro,ver;
        cin>>tim>>sub>>pro>>ver;
        int x=ch[sub];
        vis[x]=1;
        if(ver=="CE")
        {
            a[x][pro[0]-'A']=0;
        }
        else if(ver=="AC")
        {
            a[x][pro[0]-'A']=max(dis[pro[0]-'A']/10*3,dis[pro[0]-'A']-tim*(dis[pro[0]-'A']/250)-b[x][pro[0]-'A']*50);//按照题目要求算分
            b[x][pro[0]-'A']++;
        }
        else
        {
            a[x][pro[0]-'A']=0;
            b[x][pro[0]-'A']++;
        }
    }
    for(int i=0;i<n;i++)//算总分
    {
        sum[i]=0;
        for(int j=0;j<5;j++)
            sum[i]+=a[i][j];
    }
    int x=1,y=0;
    for(int i=0;i<n;i++)//总人数
    {
        if(vis[i]==1)
            y++;
    }
    for(int i=0;i<n;i++)//cnz的排名
    {
        if(sum[i]>sum[ch["cnz"]])
            x++;
    }
    if(vis[ch["cnz"]]==1)
    {
        printf("%d\n",sum[ch["cnz"]]);
        printf("%d/%d\n",x,y);
    }
    else
        printf("-1\n");
    return 0;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值