2021-01-11

杭电2093考试排名

代码:

#include<iomanip>
#include<stdio.h>
#include<iostream>
#include<algorithm>
using namespace std;
struct acm   
{
    char name[100];
    int ac;
    int sj;
}ss[10000];
bool cmp(acm a,acm b)  //排序函数
{
    if(a.ac==b.ac)
    {
        return a.sj<b.sj;  //成绩为时间,越小越大
    }
    else
    {
        return a.ac>b.ac;  //ac数,大则大。
    }
}
int main()
{
    int z=0;
    int n,m;
    cin>>n>>m;    //输入考试题数n,单位罚分数m。
        while(cin>>ss[z].name)  //没有规定人数,直接用while循环
        {
            for(int a=0;a<n;a++)
            {
                char ch;  //定义一个字符,在下面用于接收“(”
                int k,l;
                cin>>k;  //接收成绩
                if(k<=0)
                {
                    continue;  //如果输入的成绩小于0则跳出当前循环,进行下一次循环。
                }
                ss[z].ac++; //没有跳出循环的话,程序从上而下,执行这条语句,ac数+1
                ss[z].sj+=k;//当前人的总成绩
                if(getchar()=='(')//如果有字符“(”,接收且判断。Getchar()用于只接收一个字符。
                {
                    cin>>l;   //接收罚题次数
                    cin>>ch;  //接收字符“)”
                    ss[z].sj+=l*m; //总成绩加上罚时
                }
            }
            z++;  //次数+1,此用于判断总统计人数。不然没有办法输出。
        }
    sort(ss,ss+n,cmp); //结构体排序
    for(int i=0;i<z;i++)
    {
        cout<<left<<setw(10)<<ss[i].name<<" "<<right<<setw(2)<<ss[i].ac<<right<<" "<<setw(4)<<ss[i].sj<<endl;  //setw前带left,或者right表示数据左对齐还是有对齐,setw(n)表示n个长度。
    }
    return 0;

通过读题,首先定义结构体,我对结构体的理解:结构体就像是数组的数组一样。然后通过这样对每一个名字对应一个数组,然后依次输入,如果识别到左括号,就输入并提取括号内的数字并计算罚时,这是再调用sort排序函数进行由大到小排序,当做题数量相同时,通过bool类型函数,返回罚时小的值,再通过for循环遍历输出。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值