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

ops/2024/10/20 6:24:52/

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("clear");

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

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

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

11.构造思想:

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

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

代码展示

#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);
}


http://www.ppmy.cn/ops/92040.html

相关文章

NSS [SWPUCTF 2022 新生赛]file_master

NSS [SWPUCTF 2022 新生赛]file_master 开题&#xff0c;一眼文件上传。 network看看返回包。后端语言是PHP。 除了文件上传还有个查看文件功能。 起手式查询/etc/passwd&#xff0c;发现查询方法是GET提交参数&#xff0c;后端使用file_get_contents()函数包含文件。同时有op…

如何确保工业交换机电源安全运行

在现代工业自动化和智能制造中&#xff0c;工业交换机作为网络通信的重要设备&#xff0c;其电源的安全运行显得尤为重要。为了确保工业交换机在各种恶劣环境下的稳定性与可靠性&#xff0c;我们需要采取一系列的措施和策略。首先&#xff0c;选择高质量的电源设备是基础&#…

机器学习·L3W1-聚类和异常检测

Kmean聚类 初始化聚类中心(随机选择)更新类别计算新的聚类中心 随机选择样本点作为聚类中心 K个聚类中心的情况 randidxnp.random.permutation(X.shape[0])initial_centersX[randidx[:K]]更新类别 公式是计算每一个聚类中心和当前样本的距离&#xff0c;挑选一个最短距离作为…

机械学习—零基础学习日志(高数23——无穷小运算)

零基础为了学人工智能&#xff0c;真的开始复习高数 这段时间&#xff0c;把张宇老师讲解考研的第一部分基本全部学习完毕了。 这里把第一部分的内容最后汇总一下。 无穷小运算——吸收律 这里展示一些无穷小的具体计算思路 无穷小运算——计算方法 泰勒展开的原则 夹逼准则…

探索 Go 语言的 json 库

在 Go 语言中&#xff0c;json 包是一个用于处理 JSON 数据的原生库&#xff0c;它能够将 JSON 数据编码和解码为 Go 的原生类型。以下是对 json 包中一些核心方法的介绍和示例。 1. Unmarshal 方法 Unmarshal 是 json 包中最常用的方法之一&#xff0c;它将 JSON 编码的数据…

二进制分组背包优化

前言&#xff1a;好久没有写分组背包了&#xff0c;写一个二进制优化的背包练练手 #define _CRT_SECURE_NO_WARNINGS #include<bits/stdc.h> using namespace std;#define int long long int n,w; const int N (int)1e7; struct node{int value,weight; }sto[N]; int d…

go之依赖注入框架wire

一、wire Wire 是一个代码生成工具&#xff0c;它使用依赖注入自动连接组件。 二、快速使用 2.1 引入依赖 go get github.com/google/wire go install github.com/google/wire 2.2 demo教程 2.2.1 结构体定义 type A struct { }type B struct { }type AB struct {a Ab …

翰德恩赋能中国邮政信息科技产品创新系列培训

为了增强中邮信科公司需求分析工程师的专业素养&#xff0c;提升其业务需求和业务价值的挖掘能力&#xff0c;进而设计并交付满足用户期望的产品&#xff0c;提升用户体验&#xff0c;运营管理部于2024年4月至6月成功举办了六期需求分析工程师能力提升系列培训。 本次系列培训…