牛客寒假算法基础集训营2 B处女座与cf (模拟)

本文详细解析了Codeforces比赛的得分与排名规则,包括题目的分值变化、错误提交的罚时、hack机制的影响等。并通过示例展示了如何计算处女座选手在比赛中可能获得的得分和排名。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述
众所周知,处女座经常通过打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分

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

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

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

  4. 一个人只有提交(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
注意:
1.以最后一次提交作为结果,比如ac之后又wa,当作wa
2.提交ce是无效提交,不扣分,但是有效参赛
3.ac之后又ac,上次的ac作为错误提交,相当于wa
4.细心,观察开数组,用映射解决提交过程中选手的编号

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<string>
#include<cstring>
#include<vector>
#include<set>
#include<map>
#include<stack>
#include<queue>
#include<cmath>
#include<cctype>
using namespace std;
#define PI acos(-1.0)
typedef long long ll;
typedef pair<int,int> pii;
typedef pair<ll,ll> pll;	
const int INF32M=0x3f3f3f3f;
const ll INF64M=0x3f3f3f3f3f3f3f3f;
const int maxn=1e5+5;
int r[10]={500,1000,1500,2000,2500};//该题总分30% 总分/250*t 
int vis[505];//名次 总数为有效参赛人数 
int b[505][10];//该人该题得分 
int a[505][10];//该人编号 对应题目 有效提交的错误次数 
int score[505];//n个人总分 cnz名次比较 输出cnz分数 
int main()
{
	ios::sync_with_stdio(false);
	int n,m;
	cin>>n>>m;
	
	map<string,int> mp;//编号被访问 
	for(int i=1;i<=n;i++)
	{
		string s;
		cin>>s;
		mp[s]=i;//编号 
	}
	
	for(int i=1;i<=m;i++)
	{
		int t;
		string name,id,status;
		cin>>t>>name>>id>>status;
		int x;
		x=mp[name];
		vis[x]=1;
		if(status=="CE")//无效的提交 不得分 
		{
			b[x][id[0]-'A']=0;
		}
		else if(status=="AC")
		{
			b[x][id[0]-'A']=max(r[id[0]-'A']/100*30,r[id[0]-'A']-r[id[0]-'A']/250*t-a[x][id[0]-'A']*50);
			a[x][id[0]-'A']++;
		}
		else//WA TLE不得分 有效的错误次数++ 
		{
			b[x][id[0]-'A']=0;
			a[x][id[0]-'A']++;
		}
	}
	int x=1,y=0;//同名次的话处女座名次x不后退
	for(int i=1;i<=n;i++)
	{
		if(vis[i]==1)
			y++;
	}
	for(int i=1;i<=n;i++)
	{
		score[i]=0;
		for(int j=0;j<5;j++)
			score[i]+=b[i][j];//每个人的总分 
	}
	for(int i=1;i<=n;i++)
	{
		if(score[i]>score[mp["cnz"]])//cnz未参赛 自动添加"cnz" value=0 score[0]=0; x++; cnz名次后退 不影响 不参赛-1 
			x++;
	}
	if(vis[mp["cnz"]])//若cnz未参赛 key自动添加 value为默认值0 vis[0]=0; 
	{
		cout<<score[mp["cnz"]]<<endl;
		cout<<x<<"/"<<y<<endl;
	}
	else
		cout<<-1<<endl;
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值