zoukankan      html  css  js  c++  java
  • 2B.处女座与cf(C++)

    处女座与cf(C++)

    点击做题网站链接

    题目描述
    众所周知,处女座经常通过打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(5000.3,500-250(得分衰减)-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”

    示例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

    解题代码:

    #include <iostream>
    #include <algorithm>
    #include <map>
    using namespace std;
    map<string,int> p;//下标为参赛昵称,内部存储
    int a[505][6];//错误提交的次数
    int b[505][6];//每个人每道题分数
    int r[6]={500,1000,1500,2000,2500};//储存每道题目的分数
    int mark[505];//每个人总分
    bool vis[505];//是否参加比赛
    int n,m,t;//n为报名比赛的人数,m为提交的个数,t为提交时间
    int main()
    {
        ios::sync_with_stdio(0);//加速
        cin >> n >> m;
        string name,ans;//提交者昵称,返回的结果
        char id;//题目名称
        for(int i=0;i<n;++i)
        {
            cin >> name;
            p[name] = i;
        }
        
        for(int i=0;i<m;++i)
        {
            cin >> t >> name >> id >> ans;
            int x = p[name];
            vis[x] = 1;//参加比赛记位1
            if(ans=="CE") b[x][id-'A']=0;//无效的提交得不到分
            else if(ans=="AC")//有效提交“AC”
            {
                b[x][id-'A'] = max(r[id-'A']*3/10,r[id-'A']-t*(r[id-'A']/250)-50*a[x][id-'A'] );
                a[x][id-'A']++;//你每进行一次提交,对于这一题之前的有效提交(AC,WA,TLE)都视为错误的提交。
            }
            else//“WA”“TLE”
            {
                a[x][id-'A']++;
                b[x][id-'A']=0;
            }
        }
        
        for(int i=0;i<n;++i)
        {
            mark[i]=0;
            for(int j=0;j<5;j++)
                mark[i] += b[i][j];
        }
        
        int y=0,x=1;//分母,分子
        for(int i=0;i<n;++i)
            if(vis[i]==1)
                y++;
        for(int i=0;i<n;++i)
            if(mark[p["cnz"]]<mark[i])
                x++;
        if( vis[p["cnz"]]==1 )
        {
            cout << mark[p["cnz"]] << endl;
            cout << x << "/" << y;
        }
        else cout << "-1" << endl;
     }
    
  • 相关阅读:
    2020-03-03
    2020-03-02
    2020-03-01
    2020-02-29
    简单自我介绍
    福大软工1816 · 第六次作业
    福大软工1816 · 第五次作业
    python爬虫解决编码问题
    第四次作业-团队介绍
    福大软工1816 · 第三次作业
  • 原文地址:https://www.cnblogs.com/yuzilan/p/10626083.html
Copyright © 2011-2022 走看看