zoukankan      html  css  js  c++  java
  • 洛谷 P1093 奖学金

    题目描述

    某小学最近得到了一笔赞助,打算拿出其中一部分为学习成绩优秀的前5名学生发奖学金。期末,每个学生都有3门课的成绩:语文、数学、英语。先按总分从高到低排序,如果两个同学总分相同,再按语文成绩从高到低排序,如果两个同学总分和语文成绩都相同,那么规定学号小的同学 排在前面,这样,每个学生的排序是唯一确定的。

    任务:先根据输入的3门课的成绩计算总分,然后按上述规则排序,最后按排名顺序输出前五名名学生的学号和总分。注意,在前5名同学中,每个人的奖学金都不相同,因此,你必须严格按上述规则排序。例如,在某个正确答案中,如果前两行的输出数据(每行输出两个数:学号、总分) 是:

    7279279
    5279279

    这两行数据的含义是:总分最高的两个同学的学号依次是77号、55号。这两名同学的总分都是 279279 (总分等于输入的语文、数学、英语三科成绩之和) ,但学号为77的学生语文成绩更高一些。如果你的前两名的输出数据是:

    5279279
    7279279

    则按输出错误处理,不能得分。

    输入输出格式

    输入格式:

     

    共n+1行。

    11行为一个正整数n( le 300)n(300),表示该校参加评选的学生人数。

    22到n+1n+1行,每行有33个用空格隔开的数字,每个数字都在00到100100之间。第jj行的33个数字依次表示学号为j-1j1的学生的语文、数学、英语的成绩。每个学生的学号按照输入顺序编号为1~n1 n(恰好是输入数据的行号减11)。

    所给的数据都是正确的,不必检验。

     

    输出格式:

     

    共5行,每行是两个用空格隔开的正整数,依次表示前55名学生的学号和总分。

    输入输出样例

    输入样例#1: 
    6
    90 67 80
    87 66 91
    78 89 91
    88 99 77
    67 89 64
    78 89 98
    
    输出样例#1: 
    6 265
    4 264
    3 258
    2 244
    1 237
    
    
    输入样例#2: 
    8
    80 89 89
    88 98 78
    90 67 80
    87 66 91
    78 89 91
    88 99 77
    67 89 64
    78 89 98
    输出样例#2: 
    8 265
    2 264
    6 264
    1 258
    5 258

    解析
    测试一下priority_queue,注意的是排序规则根sort正好相反,默认以大于为基准

    代码
    #include<bits/stdc++.h>
    using namespace std;
    
    struct make_stu
    {
        int chinese;
        int num;
        int math;
        int English;
        int all;
    };
    
    make_stu stu[500];
    
    struct cmp
    {
        bool operator() (make_stu a,make_stu b)//重载运算符
        {
            if(a.all==b.all)
            {
                if(a.chinese==b.chinese)
                {
                    return a.num>b.num;    
                }
                else return a.chinese<b.chinese;
            }
            else return a.all<b.all;
        }
    };
    
    priority_queue<make_stu, vector<make_stu>, cmp> pq;
    
    int main()
    {
        int n;
        cin>>n;
        for(int i=1;i<=n;i++)
        {
            cin>>stu[i].chinese>>stu[i].math>>stu[i].English;
            stu[i].all=stu[i].chinese+stu[i].math+stu[i].English;
            stu[i].num=i;
            pq.push(stu[i]);
        }
        int flag=0;
        while(!pq.empty())
        {
            flag++;
            cout<<pq.top().num<<" "<<pq.top().all<<endl;
            pq.pop();
            if(flag==5) break;
        }
        cout<<endl;
        return 0;
    }











  • 相关阅读:
    JDBC
    两道关于回溯法,分支限界法的算法题
    旅行售货员问题
    jdbc学习
    mysql简单练习
    取会邮件客户端中的密码
    触发器的使用
    事务的数据一致性测试
    读取其他软件listview控件的内容
    sqlserver2008 ,只能选C盘目录,不能选其它盘目录
  • 原文地址:https://www.cnblogs.com/KyleDeng/p/9914090.html
Copyright © 2011-2022 走看看