C语言:输入学生信息(学号姓名成绩)并按成绩高低升序输出

  • Post author:
  • Post category:其他


题目:

定义学生结构体Student(含学号、姓名、成绩)和排序函数sort,该函数使用冒泡排序法按成绩升序排序。在主函数中输入5个学生的学号、姓名和成绩,调用sort函数对学生数据排序,最后输出排序后的学生全部信息。

主要考察的知识点:

  1. 结构体数组的元素输入输出。

  1. 结构体作为参数传递。

  1. 冒泡排序法。

解题思路:

  1. 定义学生信息结构体。

  1. 定义两数交换函数。

  1. 定义冒泡排序函数。

  1. 主函数中输入学生信息。

  1. 调用排序函数。

  1. 输出学生信息。

代码:

#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 版权协议,转载请附上原文出处链接和本声明。