日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

2B.处女座与cf(C++)

發布時間:2025/4/16 c/c++ 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2B.处女座与cf(C++) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

處女座與cf(C++)

點擊做題網站鏈接

題目描述
眾所周知,處女座經常通過打cf來調節自己的心情。今天處女座又參加了一場cf的比賽,他知道了所有的提交記錄,他想知道自己的得分和排在第幾名。你知道處女座的cf賬號是cnz

Codeforces規則如下:

  • 比賽一共2小時
  • 比賽有5題,A題500分,B題1000分,C題1500分,D題2000分,E題2500分。
  • 得分規則如下:
    在第0分鐘完成某一題可以得到全部的分數,每過一分鐘每題的分值會衰減1/250,比如在第3分鐘完成A題,能夠得到500-2*3=494分
  • 如果一道題是的返回結果WA或者TLE被稱為錯誤的提交,CE視為無效的提交,AC,WA和TLE 都視為有效的提交。如果一道題你最后通過了,你會得到這道題衰減之后的分值再減去你錯誤提交次數*50,就是每次錯誤的提交會有50分的罰時。
  • 如果你通過了一道題,你的得分不會低于該題分值的30%。比如你在第50分鐘通過了A,你有7次錯誤的提交,你的得分為max(5000.3,500-250(得分衰減)-7*50(錯誤提交的罰時))=150分。
  • 由于hack機制的存在,你每進行一次提交,對于這一題之前的有效提交(AC,WA,TLE)都視為錯誤的提交。
  • 一個人只有提交(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;//參加比賽記位1if(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;}

    轉載于:https://www.cnblogs.com/yuzilan/p/10626083.html

    總結

    以上是生活随笔為你收集整理的2B.处女座与cf(C++)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。