C语言成绩管理系统实例 附源码(一)_学生成绩管理系统c语言源代码

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

(3)每个模板作为一个单独的c文件,每个文件内的函数名如表2-1-1所示表中给出了各个函数的功能说明。

(4)宏和数据结构等在头文件里,并实现条件编译。

源文件函数名或者其他成分功能
Sort.csortInfo排序函数
student.cmain总控函数
menu_select菜单选择
handle_menu菜单处理
quit结束运行
add_disp.cshowTable输出表头
addRecord在表尾追加信息
display显示信息
getIndex排序的位置函数
quee_remv_modi.cremoveRecord删除指定记录
findRecord查找指定记录
querInfo查询指定学生信息
copyRecord复制记录
modifyRecord修改指定学生信息
save_load.csave文件储存
load文件读取
studebt.h常数提供常数
结构声明学生成绩结构
库函数及函数原型声明引入库函数及函数

程序包括文件的存、取过程,其功能就是在按输入顺序建立记录,如果原来没有记录文件,可以重建一个文件,如果也有记录,可以先把文件读入,然后再把新记录追加到原来记录的尾部,也可以单独建立新文件,以后再使用读取文件的方法拼装。

由以上功能分析可以看到该程序的全貌。因为它有并列选择,所以可以用选择菜单方便地实现。这个菜单及9个选择项,用switch语句实现这些选择。可以用简洁方便的伪码对他们进行描述。

3.4 函数设计分析

为一些函数设计两个返回值以区分其执行结果是否正确。每个学生信息资料用一个StuInfo结构来保存,用StuInfo数组全局变量records来保存一批学生的信息资料。宏定义INITIAL SIZE表示数组初始大小,当已分配的数组大小不够用时,将增加数组大小,INCR SIZE为当每次增加的大小。全局变量numstus表示数组中记录的学生数,arraysize是为数组分配的空间大小。全局变量 savedTag是信息是否已保存的标志:当数组内容被保存至文件后,设为"已保存"状态;当数组内容被修改之后,设为"未保存"状态。

下面分别描述这些函数,建立它们的函数原型.

1.文件存储操作函数

函数原型:int saveRecords(void)

功 能:将记录存入默认文件 stu info或者指定文件。

参 数:void。

返回值:成功0,失败-1。

工作方式:数组records被保存至指定文件。

要 求:报告是否有记录可存、是否正常建立或打开文件、根据要求执行存人操作并报告存入记录的条数。

2.文件读取操作函数

函数原型:int loadRecords(void)

功 能:将默认文件 stu_info或者指定文件里的记录读入内存。

参 数:void。

返回值:成功0,失败-1。

工作方式: records将为从指定文件中读取出的记录。

要 求:报告是否有记录可存、能否能正常打开文件、是否覆盖已有记录以及读录的条数。

3.显示所有学生信息的函数

函数原型:void display(void)

功 能:显示内存里的记录信息。

参 数:void。

返回值:void。

工作方式:从头部开始逐个显示记录内容。

要 求:报告是否有记录及记录条数和内容。

4.增加信息函数

函数原型:void addRecord(void)

功 能:增加记录。

参 数:void。

返回值:void。

工作方式:从尾部开始逐个追加记录。

要 求:将新记录追加在记录尾部,并对记录进行计数。

5.输出表头函数

函数原型:void showTable(void)功 能:输出表头信息。

参 数:void。

返回值:void。

工作方式:输出一行表头信息。

要 求:输出一行表头信息。

6.删除记录函数

函数原型:void removeRecord(void)。

功 能:删除内存数组中的指定记录。

参 数:void。

返回值:void。

工作方式:根据给定的关键字,查找符合的记录并删除。

要 求:将后面的记录前移,同时调整名次并给出相关信息。

7.查找指定记录函数

函数原型:int findRecord(char*, int, int)

功 能:查找指定记录。

参 数:charstarget:欲查找记录的某一项与target 相同。

Int targetType:表明通过哪一项来查找,0为学号,1为姓名,2为名次。

int from:从第from个记录开始找。

返回值:Int:找到的记录的序号,若找不到则返回-1。

工作方式:根据给定的关键字,查找符合记录的序号。

要 求:找不到则返回-1。

8.查询指定学生信息的函数

函数原型:void queryInfo(void)。

功 能:将一个文件的内容追加到另一个文件的尾部。

参 数void。

返回值:void。

工作方式:可以按照学号、姓名或名次来查询。

要 求:打印查询到的学生的信息或给出相关信息。

9.记录复制函数

函数原型:void copyRecord(StuInfo*,stuInfo*)

功 能:将 src指向的一条记录复制给 dest指向的记录。

参 数:StuInfo* src:源记录

StuInfo* dest:目的记录。

返 回 值:void。

工作方式:将源记录逐条复制到目的记录。

要 求:正确复制字符串。

10.修改指定学生信息函数

函数原型: void modifyRecord(void)

功 能:找到指定记录并修改。

参 数:void。

返 回 值:void。

工作方式:可以按照学号、姓名或名次找到要修改的记录,确认后方可修改。

要 求:同时需要调整名次。

11.学生信息排序函数

函数原型:void sortInfo(void)能:对记录进行排序。

参 数:无。

返回值:无。

工作方式:可以按照学号、姓名或名次进行排序。

要 求:升序或降序排序。

12.排序的位置函数

函数原型:int getIndex(float sum)

功 能:找出总分为sum在第0~numstus-1个记录中按升序排序的位置。

参 数:float,欲找出其位置的总分。

返回值:int, sum在第0~numstus-1个记录中按升序排序。

工作方式:查找并计数。

要 求:输出位置整数。

13.菜单处理函数

函数原型:void handle menu(void)

功 能:处理选择的菜单命令

参 数:vo1d。

返 回 值:void。

工作方式:根据命令,调用相应函数。

要 求:给出结束信息。

14.菜单选择函数

函数原型:int menu_select(void)能:接收用户选择的命令代码。

参 数:void。

返回值:1nt。

工作方式:返回命令代码的整数值。

要 求:只充许选择规定键,如果输入不符合要求,则提醒用户重新输入。

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

求:只充许选择规定键,如果输入不符合要求,则提醒用户重新输入。

[外链图片转存中…(img-6qj0gUn5-1715741178277)]
[外链图片转存中…(img-RHd2KPj8-1715741178277)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

技术特点:采用三层架构模式、数据分页、获取等均使用代码实现。注释详细、代码规范,非常适合学习和中小型学校使用。 功能描述: 一,可以导入和导出成绩,成绩单上的项目包括:姓名,学号,科目,班级,成绩,补考成绩,授课老师,考试日期。 其中成绩和补考成绩具体情况如下: 1,计算机课程:理论成绩,实践成绩,, 2,文化课:理论, 3,英语:考试成绩,平时成绩,总成绩 二,导入成绩后,系统会自动计算出该班级该科目的应考人数,实考人数,缺考人数,及格人数,不及格人数,平均分,通过率。 其中平均分和率具体情况如下: 1,计算机课程:理论成绩,实践成绩,总成绩(理论和实践各占50%) 2,文化课:理论, 3,英语:考试成绩,平时成绩,总成绩(考试成绩占80%,平时成绩占20%) 4,计算机课程: 理论平均分,通过率;实践平均分,通过率;总成绩的平均分,通过率。 5,文化课:理论成绩的平均分,通过率 6,英语:总成绩的平均分和通过率 三:查询: 1,可以通过班级,学号,姓名,科目,及格的人和不及格的人,授课老师进行查询, 2,可以查询该班的单科成绩,也可以查询该班的各科成绩汇总。 3,可以按月度查询该月所有考试的平均分和通过率,也可 以按年度查询该年度的平均分和通过率。 4,可以查询授课老师某一门的月度和年度平均分和通过率和该老师所授所有课程的月度和年度平均分和通过率。 四、成绩排序 可按照该班级某门课程的理论成绩,实践成绩、总成绩进行排序 五、任课教师的管理 任课教师基本信息,该门课程的授课教师 教务处: 学校全体成员的信息管理,对考试科目,时间及对所考科目的编号等进行具体的管理,并对任课老师等输入的信息进行管理,对学生的信息进行必要的维护,可打印学生的所有信息。 绝对是可用实际部署使用的。很实惠的。 注意事项:运行时请修改加数据库并修改数据库连接字符串(在web.config里面)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值