题是这样的:

试题描述

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

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

7279

5279

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

5279

7279

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

输入

包含n+1行: 
第1行为一个正整数n,表示该校参加评选的学生人数。 
第2到n+1行,每行有3个用空格隔开的数字,每个数字都在O到100之间z第1行的3个数 字依次表示学号为j-1的学生的语文、数学、英语的成绩。每个学生的学号按照输入顺序编号为l~n (恰好是输入数据的行号减1)。

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

输出

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

输入示例

【输入样例1】 
6      
90 67 80  
87 66 91    
78 89 91     
88 99 77     
67 89 64       
78 89 98       
【输入样例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  
输出示例

【输出样例1】 
6 265
4 264
3 258
2 244
1 237
【输入样例1】 
8 265
2 264
6 264
1 258
5 258

其他说明

【限制】50%的数据满足:各学生的总成绩各不相同 100%的数据满足: 6<=n<=300

这题。。。好吧,这个题还是可以的。(水)。。。

这道题可以运用一下自定义类

(stuct)

例如:

struct student
{
    int yuwen, english, math ,id;//我相信你能读懂!
    //yuwen:语文
    //english:英语
    //math:数学
    //id:学号
    int sum;
    //sum:总分
}a[maxn];

但是,问题来了,怎么排序?

看来还是得重载运算符(本人曾经在其他博客中写过这个运算符重载的模板)

bool operator < (const student &a) const
{
    if(sum == a.sum)//先比较总分
    {
         //如果总分相同,比较语文
    if(yuwen != a.yuwen) return yuwen < a.yuwen;
    //如果语文也相同,就比较学号
    return id > a.id;
    }
    return sum < a.sum;
}

这样的话,就可以用sort排序了,运算速度大幅提升

    sort(a,a+n);//直接排序

总结一下这个student类

struct student
{
    int yuwen, english, math ,id;//我相信你能读懂!
    //yuwen:语文
    //english:英语
    //math:数学
    //id:学号
    int sum;
    //sum:总分
    bool operator < (const student &a) const
    {
        if(sum == a.sum)//先比较总分
        {
            //如果总分相同,比较语文
            if(yuwen != a.yuwen) return yuwen < a.yuwen;
            //如果语文也相同,就比较学号
            return id > a.id;
        }
        return sum < a.sum;
    }
}a[maxn];

这就可以了!

源代码,已经AC

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstdlib>
#include<cmath>
#include<cstring>
using namespace std;
;
int n;
struct student
{
    int yuwen, english, math ,id;//我相信你能读懂!
    //yuwen:语文
    //english:英语
    //math:数学
    //id:学号
    int sum;
    //sum:总分
    bool operator < (const student &a) const
    {
        if(sum == a.sum)//先比较总分
        {
            //如果总分相同,比较语文
            if(yuwen != a.yuwen) return yuwen < a.yuwen;
            //如果语文也相同,就比较学号
            return id > a.id;
        }
        return sum < a.sum;
    }
}a[maxn];
int main()
{
    scanf("%d",&n);
    ;i<n;i++) scanf(;//输入
    sort(a,a+n);//直接排序
    ;i>n-;i--) printf("%d %d\n", a[i].id, a[i].sum);//输出
}

谢谢大家,欢迎大家继续关注我。

NOIP200701的更多相关文章

  1. NOIP201101&&05

    NOIP200701奖学金 难度级别:A:            运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述    某小学最近得到了一笔赞助 ...

随机推荐

  1. CAS Proxy 的相关文章

    cas代理模式的原理及配置 http://my.oschina.net/mashiguang/blog/69312 剖析CAS Proxy的设计原理 http://www.blogjava.net/s ...

  2. Samba Linux和Windows互访

    之前一直用的sshfs manager,但是会出现造成电脑黑屏的情况.网上也没找到其它类似的软件. 后面打算用Samba 直接搜到一篇很强大的文章. 1.  下载及安装Samba 推荐用yum来安装, ...

  3. 基于S7-200的PLC对里程轮(增量式码盘)解码的应用

             解码模块为JC-11:工业增量式码盘 解码模块,接口简单,易于使用. 应用Step7-MicroWIN编程软件,为S7-200PLC设计本编码盘的应用程序.由于编码盘输出的脉冲信号频 ...

  4. oracle之单行函数

     单行函数 ①.字符函数 LOWER(x):将x中的每一个单词都转换成小写 UPPER(x):将x中的每一个单词都转换成大写 INITCAP(x): 将x中的每一个单词的首字母转换成大写 CONC ...

  5. EasyARM i.mx28学习笔记——开箱试用总结

    0 前言     本月初(2014年8月)购买了周立功的EasyARM开发板,主控为EasyARM i.mx287.出于下面几个理由购买了该开发板.     [1]主要原因,有人约我一起学习一起使用该 ...

  6. -----------------------------SpringMVC理解-----------------------------

    1.用户发送请求到前端控制器(DispatcherServlet); 2.前端控制器转发请求到处理器映射器(HandlerMapping): 3.处理器映射器将拦截的Action返回到前端控制器: 4 ...

  7. PHP数据库结果集处理

    mysql连接成功后可以用msql_query来获得一个资源型的结果集. $sql = 'select * from emp_info';$result = mysqli_query($link,$s ...

  8. Javascript学习总结三(Array对象的用法)

    javascript Array对象的常用API 1:concat concat() 方法用于连接两个或多个数组.该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本.举例:var a1 = [ ...

  9. nargin函数的用法

    nargin是用来判断输入变量个数的函数,这样就可以针对不同的情况执行不同的功能.通常可以用他来设定一些默认值,如下面的函数. 函数文件examp.m:function fout=charray(a, ...

  10. 使用jvisualvm和飞行记录器分析Java程序cpu占用率过高

    一.jvisualvm使用 JDK1.6中Oracle提供了一个新的JVM监控工具:jvisualvm.下面重点介绍如何在本地通过远程的方式打开Linux服务器上的jvisualvm. 1.Xmana ...