C基础练习(学生管理系统)

1.系统运行,打开如下界面。列出系统帮助菜单(即命令菜单),提示输入命令

2.开始时还没有录入成绩,所以输入命令 L 也无法列出成绩。应提示"成绩表为空!请先使用命令 T 录入学生成绩。"

同理,当输入其他的成绩处理命令时也作相应的处理。

3.输入命令 T,调用Type子函数录入成绩。界面提示输入学生人数

输入3 后 提示输入3名学生的3门课成绩,列出成绩单的表头"学号 语文 数学 英语",提示学号:1

输入1号学生的3门课成绩,用空格间隔,回车结束。提示 学号:2

以此类推,直到输入结束

4.输入命令 L ,调用List子函数输出成绩表。List子函数调用结束,返回。 提示输入命令

5.输入命令 A ,调用Average子函数计算平均分,提示"平均分已计算。请使用命令L查看。" Average子函数调用结束,返回。 提示输入命令

输入命令 L ,调用List子函数输出成绩表。List子函数调用结束,返回。 提示输入命令

6.输入命令 P ,调用Sort子函数将各学生记录按平均分由高到低排序,提示"完成排序。请使用命令L查看。" Sort子函数调用结束,返回。 提示输入命令

输入命令 L ,调用List子函数输出成绩表。List子函数调用结束,返回。 提示输入命令

7.输入命令 S ,调用Search子函数查询学生成绩,提示"输入要查询的学生学号"。

输入3 ,找到3号学生的成绩并输出。 Search子函数调用结束,返回。 提示输入命令

8. 输入命令C , 执行清屏函数语句 system("c lear ") ;

清除屏幕的所有内容。 提示输入命令

9. 输入命令H , 调用Help子函数显示帮助菜单。Help子函数调用结束,返回。 提示输入命令

10. 输入命令Q , 则退出系统。

11.构造思想:

1)输出数组元素时,要将学号单独处理,输出为整数(即保留0位小数)。同理,在计算成绩时也要将第1列的学号撇开,只计算第2列之后的。成绩保留2位小数。

2)学生人数n贯穿始终,通过n的值判断当前命令的子函数是否能够调用执行。例如:当n=0时,说明还没有录入成绩。而一旦输入命令T,也即调用Type子函数录入了成绩,则n的值就不再是0。当n!=0时,就可以进行其他的成绩操作。

代码展示

cs 复制代码
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
struct student // 定义结构体数组,用来存放学生信息
{
    int num;
    float Chinese;
    float math;
    float English;
    float average;
} stu[32];
void Help(); // 声明函数
int Type(struct student *p, int n);
void List(int n);
void Average(int n);
void paixu(int n);
void Search(int n);
int main(int argc, char const *argv[])
{
    Help(); // 调用帮助菜单函数
    char ml;
    int n = 0;
    while (1) // 重复输入命令
    {
        printf("请输入命令=");
        scanf(" %c", &ml);
        if (ml == 'C')
            system("clear"); // 输入C时,触发清屏函数
        else if (ml == 'Q')
            break; // 输入Q时退出程序
        else if (ml == 'T')
            n = Type(stu, n); // 输入T时调用Type函数录入信息
        else if (n == 0)      // 当学生人数为0时无法使用其它命令,需要先录入信息
            printf("成绩表为空!请先使用命令T录入学生成绩\n");
        else if (n != 0)
        {
            if (ml == 'H')
                Help(); // 当输入H时调用Help函数打开帮助菜单
            else if (ml == 'L')
                List(n); // 输入L时调用List函数列出学生信息
            else if (ml == 'A')
                Average(n); // 输入A时调用Average函数计算平均分
            else if (ml == 'P')
                paixu(n); // 输入P时调用paixu函数进行排序
            else if (ml == 'S')
                Search(n); // 输入S时调用Search函数进行查询
        }
        getchar(); // 回收垃圾字符
    }
    return 0;
}
int Type(struct student *p, int n) // 录入信息函数
{
    int num;
    printf("请输入学生人数:");
    scanf("%d", &num);
    printf("请输入%d个学生的成绩\n", num);
    printf("学号  语文  数学  外语\n");
    for (int a = n; a < n + num; a++) // for循环遍历录入信息
    {
        printf("%d  ", a + 1);
        stu[a].num = a + 1;
        scanf("%f %f %f", &stu[a].Chinese, &stu[a].math, &stu[a].English);
    }
    n = num + n;
    return n; // 返回学生人数
}
void Help() // 帮助菜单
{
    printf("**************************************\n");
    printf("*  学生成绩管理系统------------帮助菜单      *\n");
    printf("**************************************\n");
    printf("*        H=显示帮助菜单              *\n");
    printf("*        T=成绩录入                  *\n");
    printf("*        A=计算学生平均分            *\n");
    printf("*        L=列出成绩表                *\n");
    printf("*        P=按平均成绩由高到低排序    *\n");
    printf("*        S=按学号查询学生成绩        *\n");
    printf("*        C=清屏                      *\n");
    printf("*        Q=退出系统                  *\n");
    printf("**************************************\n");
    printf(" Copyright <c>  2024.08.06 By zhr\n");
}
void List(int n) // 列出学生信息函数
{
    printf("学生成绩如下:\n");
    printf("学号 语文 数学 外语  平均分\n");
    for (int a = 0; a < n; a++) // for循环遍历结构体数组
    {
        printf("%d   %.2f  %.2f %.2f   %.2f", stu[a].num, stu[a].Chinese, stu[a].math, stu[a].English, stu[a].average);
        printf("\n");
    }
}
void Average(int n) // 计算平均分函数
{
    for (int a = 0; a < n; a++)
        stu[a].average = (stu[a].Chinese + stu[a].English + stu[a].math) / 3;
    printf("平均分已计算,请使用命令L查看\n");
}
void paixu(int n) // 排序函数
{
    struct student stu1[32];
    if (stu[0].average == 0) // 平均分未计算时无法排序
        printf("无法排序,请先使用命令A计算平均分\n");
    else
    {
        for (int a = 0; a < n - 1; a++)
        {
            for (int b = 0; b < n - 1 - a; b++)
            {
                if (stu[b].average < stu[b + 1].average)
                {
                    stu1[b] = stu[b]; // 通过交换结构体数组进行排序
                    stu[b] = stu[b + 1];
                    stu[b + 1] = stu1[b];
                }
            }
        }
        printf("已完成排序,请使用命令L查看\n");
    }
}
void Search(int n)
{
    int num;
    printf("请输入要查询的学生的学号:");
    scanf("%d", &num);
    printf("学号 语文 数学 外语  平均分\n");
    for (int a = 0; a < n; a++)
        if (stu[a].num == num) // 通过学号打印学生信息
            printf("%d   %.2f  %.2f %.2f   %.2f\n", stu[a].num, stu[a].Chinese, stu[a].math, stu[a].English, stu[a].average);
}
相关推荐
只因在人海中多看了你一眼几秒前
python语言基础
开发语言·python
2401_858286112 分钟前
101.【C语言】数据结构之二叉树的堆实现(顺序结构) 下
c语言·开发语言·数据结构·算法·
y25083 分钟前
《Object类》
java·开发语言
小技与小术7 分钟前
数据结构之树与二叉树
开发语言·数据结构·python
hccee29 分钟前
C# IO文件操作
开发语言·c#
hummhumm34 分钟前
第 25 章 - Golang 项目结构
java·开发语言·前端·后端·python·elasticsearch·golang
J老熊44 分钟前
JavaFX:简介、使用场景、常见问题及对比其他框架分析
java·开发语言·后端·面试·系统架构·软件工程
寻找码源1 小时前
【头歌实训:利用kmp算法求子串在主串中不重叠出现的次数】
c语言·数据结构·算法·字符串·kmp
zmd-zk1 小时前
flink学习(2)——wordcount案例
大数据·开发语言·学习·flink
好奇的菜鸟1 小时前
Go语言中的引用类型:指针与传递机制
开发语言·后端·golang