理解结构体的用处(偏难一些的结构体排序)

编程入门 行业动态 更新时间:2024-10-10 15:28:43

理解<a href=https://www.elefans.com/category/jswz/34/1771419.html style=结构体的用处(偏难一些的结构体排序)"/>

理解结构体的用处(偏难一些的结构体排序)

小蒜给出了班里某门课程的成绩单,请你按成绩从高到低对成绩单排序输出,如果有相同分数则名字字典序小的在前。

输入格式

第一行为 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;
}

更多推荐

理解结构体的用处(偏难一些的结构体排序)

本文发布于:2024-03-23 01:42:28,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1738976.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:结构   用处

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!