题目:
    
定义学生结构体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 版权协议,转载请附上原文出处链接和本声明。
