1004. 成绩排名

一、题目

读入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;
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值