PAT-B 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

思路分析:

初始化创建三个结构体 { 名字,学号,分数 },定义三个指针,分别代表,最大(max)最小(min)和临时存储(p)。(tmp是交换地址用的)

本题思路是用(p)获取输入,然后跟(max)和(min)比较,如果(p)的分数比(max)大,或者比(min)小,则交换地址。这样可以保证,(max)和(min)总是指向最大和最小的结构体。
为了保证(max)和(min)种的数据总是有效的,在循环开始前,读取第一组数据,同时赋给(max)和(min)。

代码:

#include <stdio.h>
#include <string.h>

int main()
{
    int n;
    struct report_{ char name[11], num[11]; int score;
    }stu[3], *p = stu, *min = p+1, *max = p+2, *tmp;

    scanf("%d", &n);
    scanf("%s %s %d", max->name, max->num, &max->score);
    memcpy(min, max, sizeof(stu[0])); // 第一组数据同时赋值给 max 和 min 

    for (int i = 1; i < n; i++) {
        scanf("%s %s %d", p->name, p->num, &p->score);
        if (p->score > max->score) // 如果 p 的分数比 max 大,交换地址
            tmp = max, max = p, p = tmp;
        else if (p->score < min->score) // 如果 p 的分数比 min 小,交换地址
            tmp = min, min = p, p = tmp;
    }

    printf("%s %s\n", max->name, max->num);
    printf("%s %s", min->name, min->num);

    return 0;
}

点这里进入试题网页

你可能感兴趣的:(pat,乙级,简洁代码)