结构体的用处(偏难一些的结构体排序)"/>
理解结构体的用处(偏难一些的结构体排序)
小蒜给出了班里某门课程的成绩单,请你按成绩从高到低对成绩单排序输出,如果有相同分数则名字字典序小的在前。
输入格式
第一行为 n(0 < n < 20),表示班里的学生数目;
接下来的 n 行,每行为每个学生的名字和他的成绩, 中间用单个空格隔开。名字只包含字母且长度不超过 20,成绩为一个不大于100 的非负整数。
4 Kitty 80 Hanmeimei 90 Joey 92 Tim 28
输出格式
把成绩单按分数从高到低的顺序进行排序并输出,每行包含名字和分数两项,之间有一个空格。
Joey 92 Hanmeimei 90 Kitty 80 Tim 28
解题思路:首先使用结构体使一个姓名对应一个分数,在主函数中输入n,确定人数。利用字符型数组(当分数相同时,用字符型数组输入可转化为ASCII码将名字按字典序排列)将姓名和分数存入,再利用冒泡排序(利用双重嵌套比较两个相邻的元素,如果他们的顺序错误就把他们交换。再进行第二次排序)直到结束。
#include "stdio.h"
#include "string.h"struct student {char name[21];int score;
};//用结构体储存姓名和分数int main() {struct student a[100], t;int i, j, n;scanf("%d", &n);//输入一个数nfor (i = 1; i <= n; i++) {//循环读入n个人名和分数scanf("%s %d", a[i].name, &a[i].score);}for (i = 1; i <= n - 1; i++) {//按分数进行排序for (j = 1; j <= n - i; j++) {if (a[j].score < a[j + 1].score) {//对分数进行比较t = a[j];a[j] = a[j + 1];a[j + 1] = t;} else if (a[j].score == a[j + 1].score) {//如果分数相同时,按字典序排序if (strcmp(a[j].name, a[j + 1].name) > 0) {t = a[j + 1];a[j + 1] = a[j];a[j] = t;}}}}for (i = 1; i <= n; i++)//输出人名printf("%s %d\n", a[i].name, a[i].score);return 0;
}
更多推荐
理解结构体的用处(偏难一些的结构体排序)
发布评论