4078. 成绩表里找同学
Posted bernieloveslife
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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;
}
以上是关于4078. 成绩表里找同学的主要内容,如果未能解决你的问题,请参考以下文章