题目:
定义学生结构体Student(含学号、姓名、成绩)和排序函数sort,该函数使用冒泡排序法按成绩升序排序。在主函数中输入5个学生的学号、姓名和成绩,调用sort函数对学生数据排序,最后输出排序后的学生全部信息。
主要考察的知识点:
结构体数组的元素输入输出。
结构体作为参数传递。
冒泡排序法。
解题思路:
定义学生信息结构体。
定义两数交换函数。
定义冒泡排序函数。
主函数中输入学生信息。
调用排序函数。
输出学生信息。
代码:
#define _CRT_SECURE_NO_WARNINGS#include#include#define N 5typedef struct {//定义学生信息结构体int id;//学号char name[10];//姓名int score;//成绩}student;void swap(int* a, int* b)//定义两数交换函数{int temp = *a;*a = *b;*b = temp;}void sort(student* a)//定义冒泡排序函数{for (int j = 0; j < N - 1; j++)//冒泡排序法:两两依次比较,数大后移for (int i = 0; i a[i + 1].score){swap(&a[i].score, &a[i + 1].score);//调用两数交换函数swap(&a[i].id, &a[i + 1].id);char temp3[10] = { };strcpy(temp3, a[i].name);//字符串复制函数,头文件是string.hstrcpy(a[i].name, a[i+1].name);strcpy(a[i + 1].name, temp3);}}int main(){student a[N];for (int i = 0; i < N; i++)//输入学生信息{printf("请输入第%d个学生的学号、姓名、成绩:",i+1);scanf("%d%s%d", &a[i].id,&a[i].name,&a[i].score);}sort(a);//调用排序函数printf("\n\t学号\t姓名\t成绩\n");for (int i = 0; i < N; i++)//输出排序后的学生信息{printf("\t%d\t%s\t%d\n", a[i].id, a[i].name, a[i].score);}return 0;}