题是这样的:

试题描述

某小学最近得到了一笔赞助,打算拿出其中一部分为学习成绩优秀的前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. ios开发 数据库版本迁移手动更新迭代和自动更新迭代

    数据库版本迁移顾名思义就是在原有的数据库中更新数据库,数据库中的数据保持不变对表的增.删.该.查. 数据持久化存储: plist文件(属性列表) preference(偏好设置) NSKeyedArc ...

  2. Atom远程连接服务器报错服务器版本和客户端版本不一致

    Atom远程连接服务器 报错信息: Server version is different than client version Original error message: Version mi ...

  3. hbase多用户入库,regionserver下线问题

    近期对hbase多用户插入数据时,regionserver会莫名奇妙的关闭,regionserver的日志有很多异常: 如下: org.apache.hadoop.hbase.DroppedSnaps ...

  4. C#-将控件动态添加到选项卡页tablepage

    tabPage1.Controls.Add(new Button()); 实例: Button cp = new Button(); cp.text="test";cp.Click ...

  5. C# 网络编程之豆瓣OAuth2.0认证具体解释和遇到的各种问题及解决

            近期在帮人弄一个豆瓣API应用,在豆瓣的OAuth2.0认证过程中遇到了各种问题,同一时候自己须要一个个的尝试与解决,终于完毕了豆瓣API的訪问.作者这里就不再吐槽豆瓣的认证文档了,毕 ...

  6. 【问题汇总】ListView的FooterView设置可见性的问题

    ListView的FooterView一般用来给用户展示一些提示信息. 正常情况下,是这么使用的.代码例如以下: // footer footerLayout = new PullLoadingLay ...

  7. iOS开发——屏幕适配篇&Masonry详解

    Masonry详解 前言 MagicNumber -> autoresizingMask -> autolayout 以上是纯手写代码所经历的关于页面布局的三个时期 在iphone1-ip ...

  8. JavaScript(20)jQuery HTML 加入和删除元素

    jQuery - 加入元素 通过 jQuery,能够非常easy地加入新元素/内容. 加入新的 HTML 内容的四个 jQuery 方法: append() - 在被选元素的结尾插入内容 prepen ...

  9. 转--23种设计模式的搞笑解释(后续放逐一C++解释版本)

    创建型模式 1.FACTORY —追MM少不了请吃饭了,麦当劳的鸡翅和肯德基的鸡翅都是MM爱吃的东西,虽然口味有所不同,但不管你带MM去麦当劳或肯德基,只管向服务员说“来四个鸡翅”就行了.麦当劳和肯德 ...

  10. C# 指针(unsafe与fixed的使用)

    c#在默认情况下生成的都是安全代码,即进行了代码托管(.NET的CLR机制好处之一是,进行代码托管,适时的释放内存,程序员便不必考虑资源的回收问题),而此时,指针不能出现在安全代码的编译条件下. 一. ...