题目:
定义学生结构体Student(含学号、姓名、成绩)和排序函数sort,该函数使用冒泡排序法按成绩升序排序。在主函数中输入5个学生的学号、姓名和成绩,调用sort函数对学生数据排序,最后输出排序后的学生全部信息。
主要考察的知识点:
-
结构体数组的元素输入输出。
-
结构体作为参数传递。
-
冒泡排序法。
解题思路:
-
定义学生信息结构体。
-
定义两数交换函数。
-
定义冒泡排序函数。
-
主函数中输入学生信息。
-
调用排序函数。
-
输出学生信息。
代码:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#define N 5
typedef 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 < N - 1-j; i++)
if (a[i].score > 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.h
strcpy(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;
}
运行结果:
版权声明:本文为lbcbjtlhmjq原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。