[编程题]文
  • 热度指数:530 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 256M,其他语言512M
  • 算法知识视频讲解
Sεlιнα(Selina) 开始了新一轮的男友海选。她要求她的男友要德智体美劳样样都全。首先进行的是文化知识竞赛。
Sεlιнα 精心准备了一套选择题,每个选择题有且只有一个正确答案。她邀请参赛男友们来答题,并回收了试卷准备批改。可是她却犯了愁。她不知道怎么快速地批改完这些试卷。她知道你是计算机大佬,就跑来请你写个程序帮她批改试卷。
Sεlιнα 会给你一份标准答案,再给你每个参赛男友的答卷。答卷中的每道题可能有一个答案, 也可能没有作答。你要做的是最后告诉 Sεlιнα 谁拿到了最高分,以及最高分的分数(分数为 分制)。Sεlιнα 喜欢优美的名字,所以如果有同样的分数,请告诉她其中字典序最小的选手名字。
不要偷懒哦!要是你告诉了 Sεlιнα 错误的答案,她会很生气的!

输入描述:
第一行两个整数 ,表示有 道选择题和 个参赛男友。第二行一个长为 的字符串,表示标准答案。其中第 个字母表示第 个选择题的答案。保证所有字母在  中。接下去 行,每两行表示一个参赛男友: 
 · 第一行一个字符串,表示参赛者姓名,保证姓名仅由大小写字母组成;
 · 第二行一个长为 的字符串,表示该参赛者的答案。其中第 个字母表示该参赛者对于第 个选择题的答案。保证所有字母在 中。 表示该参赛者未作答此题。


输出描述:
输出共两行,第一行是最高分的参赛男友姓名,第二行为其分数。
分数为 分制,保留两位小数。若有多人同分,输出字典序最小的姓名。 
示例1

输入

5 3
ADBBC
spiderman
ADBAC
niconico
BDXBC
ekstieks
ACBBC

输出

ekstieks
80.00

备注:


  姓名长度  

我们来帮可爱的Sεlιнα批改试卷喵!她想从男友们中找出文化知识竞赛的最高分者喵~

首先,代码会读取选择题的数量和男友的人数,接着读取标准答案喵~标准答案是一个字符串,每个字母对应一道题的正确答案喵~

然后,代码进入一个循环,依次处理每个男友的答卷喵~每个男友有两行信息:一行是他的名字,一行是他的答案字符串喵~答案里可能有'A'到'D'表示选的选项,还有'X'表示这道题没作答喵~

在处理每个男友时,代码会比较他的答案和标准答案,一道一道题对照喵~如果某个题的答案和标准答案一模一样,就给这个男友加一分喵~这样就能算出他的总分啦喵~

接下来是最有趣的部分喵~代码会一直追踪当前的最高分和对应的男友名字喵~
一开始还没有最高分,所以第一个男友会自动成为暂时的第一名喵~
之后每个男友的分数都会和当前的最高分比较喵~
如果分数更高,就直接更新最高分和名字!如果分数相同,就比较名字的字典序,谁的名字字典序更小谁就更优先喵~这样就能确保最终选出最高分且名字最可爱的男友喵~
最后,代码输出这位优胜男友的名字和他的分数喵~
分数是按百分制换算的,保留两位小数,这样看起来更整齐喵~

#include <bits/stdc++.h>
#include <iomanip>
#include <unordered_map>
using namespace std;
using ll=long long;

int main() {
    ll n,m;cin >> n >> m;
    string da;cin >> da;//输入答案
    ll ma=0;//最终男友分数
    string ny;//最终男友名字

    for(ll i=0;i<m;i++)
    {
        string name;cin >> name;//每个参赛者名字
        string hd;cin >> hd;//回答
        ll num=0;//得分
        for(ll i=0;i<n;i++)
        {
            if(da[i]==hd[i]) num++;//每个回答与答案相同加一分
        }
        if(num>ma||i==0)//比最终男友分高
        {
            ny=name;ma=num;//就变成最终男友
        }
        else if(num==ma)//分一样高
        {
            if(ny>name) ny=name;//字典序低的留下
        }
    }
    cout << ny <<'\n';
    cout << fixed << setprecision(2) <<100.0*ma/n;
}
/*
⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣀⣤⣤⡀⣀⣠⣤⣄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣀⣀⡀⢀⣴⣾⣷⣶⣾⣿⣿⣿⣿⣿⣿⣿⣿⣷⣾⣿⣷⣦⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣠⣾⣿⣿⣿⣿⣿⣿⣿⠿⠛⠛⠉⠉⠉⠉⠉⠉⠛⠻⠿⣿⣿⣿⣿⣿⣶⣤⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⠀⠀⠀⢠⣾⣿⣿⣿⡿⠿⠛⠉⠉⠉⠉⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠈⠙⠿⣿⣿⣿⣷⣄⡀⠀⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⠀⠀⣀⣿⣿⣿⠟⠁⠀⠀⠀⠀⠀⠀⠀⣰⡆⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠙⠿⣿⣿⣿⡄⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⣠⣾⣿⣿⠟⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣿⣶⣄⠀⠀⠀⠀⠀⢀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠈⣻⣿⣿⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⢹⣿⡿⠁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⢰⣿⠁⠈⢢⡀⠀⠀⠀⢸⡇⢀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠈⠻⣿⡟⠒⢦⡀⠀⠀⠀
⠀⠀⣠⣤⣤⣼⡟⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠸⡇⠀⠀⠀⠉⢢⣄⠀⠀⢿⠊⠳⡄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠙⣷⡄⠀⢷⠀⠀⠀
⠀⢰⠇⠀⣰⡟⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⡇⠀⠀⠀⠀⡌⣹⠗⠦⣬⣇⠀⠉⢢⡀⠀⠀⠀⠀⠀⠀⠀⠀⠘⣿⡀⢸⡄⠀⠀
⠀⡟⠀⣼⣯⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⢰⣆⢹⡀⠀⠀⠀⠉⠁⠀⠀⢀⣀⡁⠀⠀⠉⠳⢴⡆⠀⠀⠀⠀⠀⠀⢹⣧⠈⡇⠀⠀
⠀⡇⠀⠀⢻⣦⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣀⣾⠻⠉⠛⠂⠀⠀⠀⠀⠀⠀⠻⠿⣿⣿⣿⣶⣦⡀⠛⣇⠀⠀⠀⠀⠀⣈⣿⠀⡇⠀⠀
⢸⡇⠀⠀⢠⣿⣷⣦⣀⡸⣷⣦⣶⡂⠉⠉⠉⢁⣤⣶⡶⠀⠀⠀⣀⣀⡴⠀⠀⠀⠀⠀⠀⠈⠉⠉⠁⠀⡟⢀⣴⣟⣰⣾⣿⣏⣠⠇⠀⠀
⠈⡇⠀⠀⢸⣿⠁⠉⣿⠛⠛⠃⡇⠀⠀⢠⣶⣿⡿⠛⠁⠀⠀⠉⠁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠼⢿⠟⠿⢿⡏⠀⠘⣿⡀⠀⠀⠀
⠀⢷⣀⣀⣿⠇⠀⠀⢿⡇⠀⢀⢱⡀⠀⠛⠛⠉⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣼⠀⠀⢸⠇⠀⠀⢹⣿⣄⠀⠀
⠀⠀⣉⣿⡏⠀⠀⠀⠀⠀⠀⢸⣇⣳⡄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⡰⣿⠃⠀⠀⠀⠀⠀⠀⣿⠈⢧⠀
⠀⠘⣿⣿⠁⠀⠀⠀⠀⠀⠀⠘⣿⡛⣶⠀⠀⣠⠔⠒⠛⠒⠦⡀⠀⠀⠀⠀⣠⡤⠶⠤⢤⣀⠀⠀⠀⢀⣏⡄⠀⠀⠀⠀⠀⡀⣿⡆⠈⣧
⣠⡾⠛⣿⣿⣧⠀⠀⠀⠀⢸⣿⠾⢿⡿⠀⣰⠃⠀⠀⠀⠀⠀⢹⡄⠀⠀⡼⠁⠀⠀⠀⠀⠈⠙⣦⠀⢸⣿⡇⣾⣣⡀⠀⢰⣿⣿⣿⣤⠾
⡟⠀⠀⠻⣿⡟⢷⡄⣤⡀⠈⣿⡀⣸⠇⠀⠏⠀⠀⠀⠀⠀⠀⠀⡇⠀⠀⡇⢀⡀⠀⠀⠀⠀⢀⡟⠀⠀⠋⣿⣿⣿⡇⣠⣿⠿⠛⢷⡀⠀
⠀⠀⠀⠀⣿⣇⣨⣿⣿⣿⣦⣽⣷⡟⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠁⠀⠀⠃⠀⠙⠢⠤⠤⠴⢾⠀⠀⠀⠀⢸⣷⣿⣿⠟⠁⠀⠀⠈⣧⠀
⠀⠀⠀⠀⠈⠉⠉⠁⠈⠉⠈⢉⣿⡁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠈⠀⠀⠀⠀⢸⡇⠀⠀⠀⠀⠀⠀⠀⣿⠀
*/


发表于 今天 09:46:25 回复(0)
简单小模模拟拟
#include <iomanip>
#include <iostream>
using namespace std;

int main() {
    int n,m;cin>>n>>m;
    string ans;cin>>ans;
    string res;
    double mx=-1e18;
    double score=100.0/n;
    while(m--){
        double cur=0;
        string s,s1;cin>>s1>>s;
        for(int i=0;i<n;i++){
            if(s[i]==ans[i]){
                cur+=score;
            }
        }
        if(cur>mx){
            mx=cur;res=s1;
        }
        if(cur==mx){
            if(s1<res) res=s1;
        }
    }
    cout<<res<<"\n"<<fixed<<setprecision(2)<<mx;
}


发表于 今天 15:27:31 回复(0)
#include <bits/stdc++.h>
using namespace std;
typedef struct{
    string ans;
    string name;
    int score;
}person;
bool cmp(const person &a,const person &b){
    if(a.score!=b.score)return a.score<b.score;
    else return a.name>b.name;

}
int main() {
    int n,m;
    cin>>n>>m;
    string answer;
    cin>>answer;
    vector<person>v(m);
    for(int i=0;i<m;i++){
        cin>>v[i].name>>v[i].ans;
    }
      for(int i=0;i<m;i++){
        for(int j=0;j<n;j++){
            if(v[i].ans[j]=='x')v[i].score+=0;
            else if(v[i].ans[j]==answer[j])v[i].score++;
        }
      }
    sort(v.begin(),v.end(),cmp);
    cout<<v[m-1].name<<'\n';
    double s=1.0*v[m-1].score/n*100;

    cout<<fixed<<setprecision(2)<<s<<'\n';
}
发表于 今天 10:01:15 回复(0)
出题人也是挺离谱的,每道题分值平均也没说
发表于 今天 00:36:59 回复(0)

问题信息

难度:
4条回答 33浏览

热门推荐

通过挑战的用户

查看代码