一、题目
读入n名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。
输入格式:每个测试输入包含1个测试用例,格式为
第1行:正整数n
第2行:第1个学生的姓名 学号 成绩
第3行:第2个学生的姓名 学号 成绩
… … …
第n+1行:第n个学生的姓名 学号 成绩
其中姓名和学号均为不超过10个字符的字符串,成绩为0到100之间的一个整数,这里保证在一组测试用例中没有两个学生的成绩是相同的。
输出格式:对每个测试用例输出2行,第1行是成绩最高学生的姓名和学号,第2行是成绩最低学生的姓名和学号,字符串间有1空格。
输入样例:
3
Joe Math990112 89
Mike CS991301 100
Mary EE990830 95
输出样例:
Mike CS991301
Joe Math990112
二、个人理解
题目意思很清楚,可以用排序取出最大值,但是当时我在做时,因为很长时间没用c语言,一时没想起用c语言的结构体,虽然当时用python做了出来,但是对于此类题目我认为最适合的应该是结构体加上排序。关于排序我推荐采用c语言的qsort函数,虽然需要写比较函数,但是更加灵活。
python实现:
#!/usr/bin/env python
# encoding: utf-8
num=input()
i=0
result=[]
name=[]
number=[]
score=[]
while(i<int(num)):
data=input()
name.append(data.split(' ')[0]) #利用字符串的split函数取出name,并加入到name的列表中
number.append(data.split(' ')[1])
score.append(int(data.split(' ')[2]))
i=i+1
max_tag=score.index(max(score)) #利用内置max函数,寻找其最大坐标
min_tag=score.index(min(score)) #利用内置min函数,寻找其最小坐标
print(name[max_tag],number[max_tag])
print(name[min_tag],number[min_tag])
C++实现:
#include <iostream>
#include <stdlib.h>
using namespace std;
typedef struct student{
string name;
string number;
int score;
}stu; //定义学生数据结构
int cmp(const void *a,const void *b){
stu *c=(stu *)a;
stu *d=(stu *)b;
return c->score-d->score;
} //定义比较函数
int main(){
int n;
cin>>n;
int i;
stu a[n];
for(i=0;i<n;i++){
cin >>a[i].name;
cin >>a[i].number;
cin >>a[i].score;
}
qsort(a,n,sizeof(stu),cmp); //qsort函数为内置函数,在“stdlib.h”头文件中
cout <<a[n-1].name<<' '<<a[n-1].number<<endl;
cout << a[0].name<<' '<<a[0].number<<endl;
}