1004

//1004 成绩排名 (20)(20 分)
//读入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:

#include

#include

int main(int argc, const char * argv[]) {

    int n = 0;

    scanf("%d",&n);//输入学生数量

    

    char name[2][11],id[2][11],curname[11],curid[11];//二维数组,0为最大学生,1为最小学生,一维数组放当前学生

    int grade[2] = {-1,101},curgrade;//成绩默认最大值为-1,最小值为101,防止特殊情况

    

    for (int i = 0; i < n; i++) {

        

        scanf("%s %s %d",curname,curid,&curgrade);//输入当前学生

        

        if (curgrade > grade[0]) {//当前成绩大于最大值

            strcpy(name[0], curname);

            strcpy(id[0], curid);

            grade[0] = curgrade;

        }

        if (curgrade < grade[1]) {//当前成绩小于最小值

            strcpy(name[1], curname);

            strcpy(id[1], curid);

            grade[1] = curgrade;

        }

    }

    

    printf("%s %s\n%s %s\n",name[0],id[0],name[1],id[1]);//输出

    

    return 0;

}

1.在所给的范围上数组上限+1,是因为字符串数组最后以'\0'结尾
2.比较max,min时,初始时用max+1,min-1

你可能感兴趣的:(1004)