4078. 成绩表里找同学

问题描述

编写一个程序,读入 N 个同学的姓名和语数外三门功课的单科成绩,对其按照一定的排序规则排序形成一张成绩表(先按总分从高到低排序,总分相同则按语文成绩由高到低排序,仍然相同则按数学成绩由高到低排序,若总分和单科成绩均相同则最后按姓名的字典序排序)。最后给定一个数字 K(K<=N) ,输出在这张排好序的成绩表中位置在第 K 位的同学的姓名和总分。

字典序举例说明:

abc > abd
a > aa

输入输出描述

输入

  • 第一行输入一个正整数 N(1<=N<=1024),代表接下来将录入 N 个学生的成绩。
  • 接下来 N 行录入 N 条学生的成绩记录,每条记录依次为姓名,语文成绩,数学成绩,英语成绩,这四个字段以空格分隔。姓名为字符串(仅包含小写字母,不含空格,长度<=19),学生之间不会重名。三科成绩均为整数(0~100)。
  • 最后输入一个正整数 K(1<=K<=N),代表需要在成绩表中从前往后找到的位置。

输出

  • 在成绩表中从前往后处在第 K 位的同学的姓名和总分,中间以空格分隔。

程序运行示例1

Sample Input 1

2
tom 90 91 92
lucy 91 90 92
1

Sample Output 1

lucy 273

程序运行示例2

Sample Input 2

4
lily 90 100 88
jack 87 79 95
hanz 90 89 71
david 90 89 71
4

Sample Output 2

hanz 250



#include<algorithm>
#include<iostream>
using namespace std;

struct student{
    string name;
    int chinese;
    int math;
    int english;
};

student s[1025];

bool compare(student a,student b){
    if(a.chinese+a.english+a.math!=b.english+b.chinese+b.math){
        return a.chinese+a.english+a.math>b.english+b.chinese+b.math;
    }else{
        if(a.chinese!=b.chinese){
            return a.chinese>b.chinese;
        }else{
            if(a.math!=b.math){
                return a.math>b.math;
            }else{
                if(a.english!=b.english){
                    return a.english>b.english;
                }else{
                    return a.name<b.name;
                }
            }
        }
    }
}

int main(){
    int n;
    //freopen("input.txt","r",stdin);
    cin>>n;
    for(int i=0;i<n;i++){
        cin>>s[i].name>>s[i].chinese>>s[i].math>>s[i].english;    
    }
    sort(s,s+n,compare);
    int k;
    cin>>k;
    cout<<s[k-1].name<<" "<<s[k-1].chinese+s[k-1].english+s[k-1].math;
    return 0;
} 

 

posted @ 2017-11-28 19:49  bernieloveslife  阅读(997)  评论(0编辑  收藏  举报