学生成绩管理系统(C语言有结构体实现)

news/2024/11/26 4:33:09/

目录标

  • 一、要实现的功能
    • 1.首次运行
    • 2. 成绩录入
    • 3. 显示录入的成绩
    • 4. 计算平均值
    • 5. 对平均分排序
    • 6. 查询学生成绩
    • 7. 清屏
    • 8. 显示帮助菜单
    • 9. 系统
  • 二、实现代码
    • (一)所有代码在一个文件(v1)
    • (二)分文件编写(v2)

本文章介绍了一个通过C语言实现的一个简单的学生管理系统,该系统要是使用结构体数组来管理学生成绩数据的,通过该系统的练习能够对结构体的相关知识有更好的理解,提高逻辑思维能力。

一、要实现的功能

1.首次运行

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

p9qbzZj.png

开始时还没有录入成绩,所以输入命令 L 也无法列出成绩。应提示“成绩表为空!请先使用命令 T 录入学生成绩。” 同理,当输入其他的成绩处理命令时也作相应的处理。

p9qqRkn.png

2. 成绩录入

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

p9qq5lT.png

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

p9qqH0J.png

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

p9qLktI.png

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

p9qLec8.png

输入3号学生的3门课成绩,用空格间隔,回车结束。Type子函数调用结束,返回。提示输入命令。

p9qLlAs.png

3. 显示录入的成绩

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

p9qOlrD.png

4. 计算平均值

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

p9qOrZQ.png

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

p9qORzV.png

5. 对平均分排序

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

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

p9qXEy8.png

6. 查询学生成绩

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

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

p9qXQWq.png

7. 清屏

输入命令C 执行清屏函数语句system(“clear”);

p9qXGOU.png

8. 显示帮助菜单

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

p9qXdYR.png

9. 系统

输入命令Q 则退出系统。

p9qxYm8.png

二、实现代码

(一)所有代码在一个文件(v1)

main.c

#include <stdio.h>
#include <stdlib.h>struct student
{int num;float chinese;float math;float waiyu;float average;
};
/**********函数声明*********/
void Help();//帮助菜单显示函数
void Type(struct student *pstu);//成绩录入
void List(struct student *pstu);//输出成绩表
void Averange(struct student *pstu);//平均分
void Sort(struct student *pstu);//按平均分由高到底排序
void Search(struct student *pstu); //查询学生成绩
void Clear();   //清屏int manNum = 0;//学生数int main()
{char opt;   //命令变量Help();//首次运行显示帮助菜单struct student stu[10];//定义结构体数组while (1){printf("\n");printf("请输入命令=");if(scanf("%c",&opt)){//printf("scanf出现EOF错误!\n");getchar();//吃掉空格}switch (opt){case 'H':Help();break;//显示帮助菜单case 'T':Type(stu);break;//成绩录入case 'A':Averange(stu);;break;case 'L':List(stu);break;//列出成绩表case 'P':Sort(stu);break;//按平均成绩由高到低拍排序case 'S':Search(stu);break;//按学号查询学生成绩case 'C':Clear();break;//清屏case 'Q':return 0;break; //退出系统default:printf("输入命令有误!\n");break;}}return 0;
}void Help()  //帮助菜单显示函数 H
{printf("\n");for(int i=1;i<=46;i++){printf("*");}printf("\n");printf("  *      学生成绩管理系统———帮助菜单       *  \n");for(int i=1;i<=46;i++){printf("*");}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");for(int i=1;i<=46;i++){printf("*");}printf("\n");printf("  * Copyright <C> 2023.05.19  By Sunqk5665 *  \n");for(int i=1;i<=46;i++){printf("*");}printf("\n");}
void Type(struct student *pstu)//成绩录入 T
{printf("请输入学生人数:");scanf("%d",&manNum);printf("请输入%d名学生的三门课成绩:\n",manNum);printf("学号 语文 数学 外语\n");// for(int i = 0; i < manNum; i++){//     scanf("%d  %f  %f  %f",&pstu[i].num,&pstu[i].chinese,&pstu[i].math,&pstu[i].waiyu);//     //getchar();// }for(int i = 0; i < manNum; i++){pstu[i].num = i+1;printf("%d   ",pstu[i].num);scanf("%f  %f  %f",&pstu[i].chinese,&pstu[i].math,&pstu[i].waiyu);//getchar();}getchar();//吃最后一次输入后的回车
}
void List(struct student *pstu)//输出成绩表 L
{if(manNum == 0){printf("成绩为空!请先使用命令 T 录入学生成绩。\n");return;//函数到此终止}printf("学号 语文 数学 外语 平均分\n");for(int i=0; i<manNum; i++){printf(" %d   %.1f %.1f %.1f %.1f\n",pstu[i].num,pstu[i].chinese,pstu[i].math,pstu[i].waiyu,pstu[i].average);}
}
void Averange(struct student *pstu)//平均分 A
{if(manNum == 0){printf("成绩为空!请先使用命令 T 录入学生成绩。\n");return;//函数到此终止}for(int i=0; i<manNum; i++){pstu[i].average = (pstu[i].chinese + pstu[i].math + pstu[i].waiyu)/3;}printf("平均分已计算完,请使用命令 L 查看。\n");
}
void Sort(struct student *pstu) //按平均分由高到底排序 P
{if(manNum == 0){printf("成绩为空!请先使用命令 T 录入学生成绩。\n");return;//函数到此终止}struct student stTemp;//交换中转for(int i = 1; i < manNum; i++){for(int j = 0; j < manNum-i; j++){if (pstu[j].average < pstu[j+1].average){stTemp = pstu[j];pstu[j] = pstu[j+1];pstu[j+1] = stTemp;}}}printf("完成排序,请使用 L 查看。\n");
}
void Search(struct student *pstu) //按学号查询学生成绩 S
{if(manNum == 0){printf("成绩为空!请先使用命令 T 录入学生成绩。\n");return;//函数到此终止}int stuNum;printf("请输入要查询的学生学号:");scanf("%d",&stuNum);if(stuNum <= 0 || stuNum >=manNum){printf("输入学号有误!\n");}getchar();for(int i=0; i<manNum; i++){if(pstu[i].num == stuNum){printf("学号 语文 数学 外语 平均分\n");printf(" %d   %.1f %.1f %.1f %.1f\n",pstu[i].num,pstu[i].chinese,pstu[i].math,pstu[i].waiyu,pstu[i].average);}}   }
void Clear()//清屏 C
{system("clear"); //"clear"为Linux终端清屏命令(实质是向上翻页)
}

(二)分文件编写(v2)

main.c

#include <stdio.h>
#include <stdlib.h>
#include "help.h"
#include "score.h"
#include "clear.h"// int flag = 0;
int manNum = 0;//学生数
struct student stu[20]; //结构体数组定义int main()
{char opt;   //命令Help(); //首次运行显示帮助菜单while (1){printf("\n");printf("请输入命令=");if(scanf("%c",&opt)){//printf("scanf出现EOF错误!\n");getchar();//吃掉空格}switch (opt){case 'H':Help();break;           //显示帮助菜单case 'T':Type(stu);break;        //成绩录入case 'A':Averange(stu);;break;   //计算平均分case 'L':List(stu);break;        //列出成绩表case 'P':Sort(stu);break;        //按平均成绩由高到低拍排序case 'S':Search(stu);break;      //按学号查询学生成绩case 'C':Clear();break;          //清屏case 'Q':return 0;break;         //退出系统default:printf("输入命令有误!\n");break;}}return 0;
}

help.h

#ifndef _SCORE_H_
#define __SCORE_H_
#include <stdio.h>
/****函数声明***/
void Help();//帮助菜单显示函数#endif

clear.h

#ifndef _CLEAR_H_
#define _CLEAR_H_
#include <stdlib.h>
/****函数声明***/
void Clear();   //清屏#endif

score.h

#ifndef _SCORE_H_
#define _SCORE_H_
#include <stdio.h>
#include <ctype.h>/****学生结构体***/
struct student
{int num;float chinese;float math;float waiyu;float average;
};
/****函数声明***/
void Type(struct student *pstu);//成绩录入
void List(struct student *pstu);//输出成绩表
void Averange(struct student *pstu);//平均分
void Sort(struct student *pstu);//按平均分由高到底排序
void Search(struct student *pstu); //查询学生成绩#endif

help.c

#include "help.h"void Help()//帮助菜单显示函数 H
{printf("\n");for(int i=1;i<=46;i++){printf("*");}printf("\n");printf("  *      学生成绩管理系统———帮助菜单       *  \n");for(int i=1;i<=46;i++){printf("*");}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");for(int i=1;i<=46;i++){printf("*");}printf("\n");printf("  *   Copyright <C> 2023.05.19 By 孙启凯   *  \n");for(int i=1;i<=46;i++){printf("*");}printf("\n");
}

clear.c

#include "clear.h"void Clear()//清屏 C
{system("clear"); //"clear"为Linux终端清屏命令(实质是向上翻页)
}

score.c

#include "score.h"
extern int manNum;void Type(struct student *pstu)//成绩录入 T
{printf("请输入学生人数:");scanf("%d",&manNum);printf("请输入%d名学生的三门课成绩:\n",manNum);printf("学号 语文 数学 外语\n");for(int i = 0; i < manNum; i++){pstu[i].num = i+1;printf("%d   ",pstu[i].num);scanf("%f  %f  %f",&pstu[i].chinese,&pstu[i].math,&pstu[i].waiyu);//getchar();}getchar();//吃最后一次输入后的回车}
void List(struct student *pstu)//输出成绩表 L
{if(manNum == 0){printf("成绩为空!请先使用命令 T 录入学生成绩。\n");return;//函数到此终止}printf("学号 语文 数学 外语 平均分\n");for(int i=0; i<manNum; i++){printf(" %d   %.1f %.1f %.1f %.1f\n",pstu[i].num,pstu[i].chinese,pstu[i].math,pstu[i].waiyu,pstu[i].average);}
}
void Averange(struct student *pstu)//平均分 A
{if(manNum == 0){printf("成绩为空!请先使用命令 T 录入学生成绩。\n");return;//函数到此终止}for(int i=0; i<manNum; i++){pstu[i].average = (pstu[i].chinese + pstu[i].math + pstu[i].waiyu)/3;}printf("平均分已计算完,请使用命令 L 查看。\n");
}
void Sort(struct student *pstu) //按平均分由高到底排序 P
{if(manNum == 0){printf("成绩为空!请先使用命令 T 录入学生成绩。\n");return;//函数到此终止}struct student stTemp;//交换中转for(int i = 1; i < manNum; i++){for(int j = 0; j < manNum-i; j++){if (pstu[j].average < pstu[j+1].average){stTemp = pstu[j];pstu[j] = pstu[j+1];pstu[j+1] = stTemp;}}}printf("完成排序,请使用 L 查看。\n");
}
void Search(struct student *pstu) //按学号查询学生成绩 S
{if(manNum == 0){printf("成绩为空!请先使用命令 T 录入学生成绩。\n");return;//函数到此终止}int stuNum;printf("请输入要查询的学生学号:");scanf("%d",&stuNum);getchar();if(stuNum>0 && stuNum<=manNum){for(int i=0; i<manNum; i++){if(pstu[i].num == stuNum){printf("学号 语文 数学 外语 平均分\n");printf(" %d   %.1f %.1f %.1f %.1f\n",pstu[i].num,pstu[i].chinese,pstu[i].math,pstu[i].waiyu,pstu[i].average);}}}else{printf("输入的学号非法,请仔细核对!!\n");}
}

Makefile

CC=gcc
CFLAGS=-c -g
OBJS=help.o clear.o score.o main.o
a.out:$(OBJS)$(CC) $(OBJS) -o $@
$(OBJS):%.o:%.c$(CC) $(CFLAGS) $^ -o $@
.PHONY:clean
clean:rm *.o a.out

请添加图片描述


http://www.ppmy.cn/news/94616.html

相关文章

HTML <canvas> 标签

实例 如何通过 canvas 元素来显示一个红色的矩形: <canvas id="myCanvas"></canvas><script type="text/javascript">var canvas=document.getElementById(myCanvas); var ctx=canvas.getContext(2d); ctx.fillStyle=#FF0000; ctx.fi…

xxl-job 集成 SpringBoot 使用

文章目录 前言xxl-job 集成 SpringBoot 使用1. xxl-job 安装部署超链接2. 启动xxl-job3. 集成 SpringBoot 使用3.1. 添加依赖3.2. 执行器 配置3.3. 执行器组件配置3.4. XxlJob 开发步骤 4. &#xff08;BEAN模式&#xff09;示例5. GLUE(Java) 示例6. 注意 前言 如果您觉得有用…

从零开始编写一个可运行的C语言程序

目录 安装C语言编译器 安装集成IDE环境 编写C语言程序 编译C语言程序 运行可执行文件 安装C语言编译器 首先需要安装一个C语言编译器&#xff0c;C语言编译器可以选择安装GCC、Clang、MSVC等&#xff0c;这里以GCC为例。 步骤如下&#xff1a; 1&#xff09;打开终端&a…

【C++】STL——反向迭代器的模拟实现:迭代器适配器

文章目录 前言1. list 的反向迭代器模拟实现2. 思考3. 库里面反向迭代器的实现——迭代器适配器4. 反向迭代器模拟实现的改进——适配器模式5. 适配器模式的实现——一劳永逸 前言 反向迭代器的使用相信大家都已经比较熟悉了&#xff0c;那我们这篇文章具体讲什么呢&#xff1f…

关于 OpenCV 图像处理工具包 imutils 简单认知

写在前面 博文内容涉及 基本的图像处理工具包 imutils 的简单介绍以及使用Demo理解不足小伙伴帮忙指正 对每个人而言&#xff0c;真正的职责只有一个&#xff1a;找到自我。然后在心中坚守其一生&#xff0c;全心全意&#xff0c;永不停息。所有其它的路都是不完整的&#xff0…

python操作xml,实现增删改查

xml文件内容如下&#xff1a; <configuration><property name"1"><name>beyond</name><value>yanyu</value></property><property name"2"><name>beyond1</name><value>yanyu1</va…

【JavaSE】Java基础语法(二十四):时间日期类

文章目录 1. Date类2. Date类常用方法3. SimpleDateFormat类&#xff08;应用&#xff09; 1. Date类 计算机中时间原点 1970年1月1日 00:00:00 时间换算单位 1秒 1000毫秒 Date类概述 Date 代表了一个特定的时间&#xff0c;精确到毫秒 Date类构造方法 示例代码 publi…

排序算法——冒泡排序详解及优化

冒泡排序 排序的稳定性冒泡排序优化后的冒泡排序冒泡排序的复杂度 排序的稳定性 对于一个排序算法&#xff0c;假设两个相同的元素Ai和Aj 在排序前这两个元素满足条件i<j&#xff0c;即Ai在Aj之前 在排序后Ai仍在Aj之前&#xff0c;则称为排序算法为稳定排序 否则称这个算法…