zoukankan      html  css  js  c++  java
  • 洛谷 P1093 奖学金 冒泡排序

    P1093 奖学金

    时间限制1.00s
    内存限制125.00MB
     

    题目描述

    某小学最近得到了一笔赞助,打算拿出其中一部分为学习成绩优秀的前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)。

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

    //感谢 黄小U饮品 修正输入格式

    输出格式

    共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
    -----------------------------------------------------------------------------------------------------------
     1 #include<stdio.h>
     2 struct stu{
     3     int num,cn,zf; 
     4 };
     5 int n;
     6 stu ni[666];
     7 int sor();
     8 int main(){
     9     scanf("%d",&n);
    10     for(int i=1;i<=n;i++){
    11         int math,eng;
    12         scanf("%d %d %d",&ni[i].cn,&math,&eng);
    13         ni[i].num=i;
    14         ni[i].zf=math+eng+ni[i].cn;
    15     }
    16     sor();
    17     for(int i=1;i<=5;i++)
    18        printf("%d %d
    ",ni[i].num,ni[i].zf);
    19     return 0;
    20 }
    21 int sor(){
    22     for(int i=1;i<n;i++)
    23        for(int j=n;j>1;j--){
    24            if(ni[j].zf>ni[j-1].zf){
    25                stu zn;
    26                zn=ni[j];
    27                ni[j]=ni[j-1];
    28                ni[j-1]=zn;
    29            }
    30            else if(ni[j].zf==ni[j-1].zf){
    31                if(ni[j].cn>ni[j-1].cn){
    32                    stu zn;
    33                    zn=ni[j];
    34                    ni[j]=ni[j-1];
    35                    ni[j-1]=zn;
    36                }
    37                else if(ni[j].cn==ni[j-1].cn&&ni[j].num<ni[j-1].num){
    38                    stu zn;
    39                    zn=ni[j];
    40                    ni[j]=ni[j-1];
    41                    ni[j-1]=zn;
    42                }
    43            }
    44        }
    45 }
    冒泡排序
  • 相关阅读:
    什么是 canvas(画布)?
    JavaScript
    JavaScript函数
    JavaScript事件
    JavaScript获取元素
    文件拷贝——高淇JAVA300讲笔记之IO和File
    读取与写出文件——高淇JAVA300讲笔记之IO和File
    File类的常用方法2——高淇JAVA300讲笔记之IO和File
    File类的常用方法1——高淇JAVA300讲笔记之IO和File
    路径常量,绝对路径与相对路径,构造File对象——高淇JAVA300讲笔记之IO和File
  • 原文地址:https://www.cnblogs.com/lpl-bys/p/11490428.html
Copyright © 2011-2022 走看看