You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Go to file
pe4c6pn3v d081aba5eb
Update README.md
2 years ago
.vscode 123 2 years ago
.gitignore Initial commit 2 years ago
0.drawio.svg 4 2 years ago
1.drawio.svg 111 2 years ago
2.drawio.svg 333 2 years ago
3.drawio.svg 1111 2 years ago
LICENSE Initial commit 2 years ago
README.md Update README.md 2 years ago
c1函数功能zyf c1函数代码zyf 2 years ago
c2函数功能 c2函数代码zyf 2 years ago
c3函数功能 c3函数代码 2 years ago
c4 Add c4 2 years ago
c4.drawio.svg lct 2 years ago
c4.md c4 c11 2 years ago
c4函数功能 c4函数代码 2 years ago
c5,c6 c5c6 2 years ago
c5伪代码.md mty5.画图.伪代码 2 years ago
c6伪代码.md mty.6.7.伪代码 2 years ago
c7.md mty.7.8.9.md 2 years ago
c7伪代码.md mty.6.7.伪代码 2 years ago
c8.md mty.7.8.9.md 2 years ago
c8伪代码.md mty.8.画图.伪代码 2 years ago
c9.drawio.svg c9 2 years ago
c9.md mty.7.8.9.md 2 years ago
c9代码 c9 2 years ago
c9代码.md 代码 2 years ago
c10 1 2 years ago
c10.drawio.svg 111 2 years ago
c10代码 C10ZYF 2 years ago
c10代码.md 代码 2 years ago
c10伪代码 c10流程图伪代码 2 years ago
c11.drawio.svg c11流程图和伪代码 2 years ago
c11.md c4 c11 2 years ago
c11代码.md 代码 2 years ago
c11伪代码 c11流程图和伪代码 2 years ago
c12 c12 2 years ago
c12.drawio.svg c12流程图和伪代码 2 years ago
c12代码.md 代码 2 years ago
c12伪代码 c12流程图和伪代码 2 years ago
c13.md mty.c13.md 2 years ago
c14 c14 2 years ago
mty.8.drawio.svg mty.8.画图.伪代码 2 years ago
mty5.drawio.svg mty5.画图.伪代码 2 years ago
mty6.drawio.svg mty.6.7.画图 2 years ago
mty7.drawio.svg mty.6.7.画图 2 years ago
src 123 2 years ago
xitong.drawio.svg lct 2 years ago
zyfC10.drawio.svg c10流程图伪代码 2 years ago
统计学生信息 Add 统计学生信息 2 years ago

README.md

学生成绩管理系统

2023年5月21日

组长:张桐桐 组员:孟婷玉 李玉璇 周羽凡

下载地址:https://bdgit.educoder.net/pn8rjlxip/StudentSystem.git

项目简介

本学生成绩管理系统是为教师提供管理班级成绩的工具,该系统可以实现的对学生的成绩进行增、删、改、查、信息保存和信息导入等基本功能,以及对学生成绩排序和分段的扩展功能,有利于对学生成绩管理。

项目开发过程中采用 Kanban看板进行任务管理和分工协作并使用 Git 对程序代码和文档进行版本管理。任务分工情况如下:

任务 设计 开发 测试 文档
C1-C3 菜单驱动的用户界面 张桐桐 张桐桐 李玉璇 张桐桐
C4 添加学生信息 李玉璇 李玉璇 周羽凡 李玉璇
C5-C6 求和求平均 周羽凡 周羽凡 孟婷玉 周羽凡
C7-C9 排序 孟婷玉 孟婷玉 张桐桐 孟婷玉
C10 学生信息查询 张桐桐 张桐桐 李玉璇 张桐桐
C11 统计学生信息 李玉璇 李玉璇 周羽凡 李玉璇
C12 打印学生信息 周羽凡 周羽凡 孟婷玉 周羽凡
C13 将学生信息读入文件 孟婷玉 孟婷玉 张桐桐 孟婷玉
C14 从文件中读取学生信息 张桐桐 李玉璇 孟婷玉 周羽凡 张桐桐

每个成员的工作量(百分比):

张桐桐 李玉璇 周羽凡 孟婷玉
30 30 20 20

关于学生成绩管理系统 设计一个学生成绩管理系统要求采用行菜单界面进行交互具备读取、保存、打印、查询、插入和排序等基本功能能够以表格和图表形式展示数据采用CSV格式保存数据。

系统的功能性需求:

数据的读取、保存、打印、查询、插入、排序和图表展示。 系统的非功能性需求:

菜单驱动的命令行交互界面 需求分析 分析系统的功能需求和界面需求,编制用户手册如下。

C1: 启动程序 命令行中执行命令./app,系统启动,显示提示信息,然后显示功能菜单,等待用户输入命令。

学生成绩管理
1 输入分数
2 计算每个学生各门成绩的总分和平均分
3 计算每个课程的总分和平均分
4 按分数降序排序
5 按分数升序排序
6 按数据升序排序
7 按姓名的字典顺序排序
8 查找数据
9 查找姓名
10 统计分析
11 列表记录
12 写入文件
13 读取文件
0 退出
请输入你的选择:

C2: 显示命令菜单 调用 Menu() 函数显示命令菜单,用户输入选项后,将结果返回主函数

学生成绩管理
1 输入分数
2 计算每个学生各门成绩的总分和平均分
3 计算每个课程的总分和平均分
4 按分数降序排序
5 按分数升序排序
6 按数据升序排序
7 按姓名的字典顺序排序
8 查找数据
9 查找姓名
10 统计分析
11 列表记录
12 写入文件
13 读取文件
0 退出
请输入你的选择:

C3: 退出程序 选择菜单命令 0 ,再输入 y 确认,则退出程序。

请输入你的选择: 0
你确定你想进入吗?(确定/不确定): 确定
结束程序!

C4: 添加学生信息 选择菜单命令 1 假设n=4,m=3,提示输入学生的学号,姓名和成绩,然后利用循环逐个输入学生的学号和姓名以及各科成绩。

请输入你的选择1
输入学生的学号,名字和成绩:
2214111018 李玉璇 100 95 86
2214111038 张桐桐 77 89 99
2214111026 孟婷玉 85 91 98
2214111022 周羽凡 75 89 100

C5: 计算学生各门课程总分和平均分 选择菜单命令 2 ,计算学生各门课程总分和平均分,然后利用循环逐个输出学生的顺序,总成绩和平均分,结果都取整数。

请输入你的选择2
学生 李玉璇: 总分 = 281 平均分 = 93
学生 张桐桐: 总分 = 265 平均分 = 88
学生 孟婷玉: 总分 = 274 平均分 = 91
学生 周羽凡: 总分 = 264 平均分 = 88

c6:计算每门课程的总分和平均分 选择菜单命令 3计算每门课程的总分和平均分然后利用循环逐个输出每门课程的总分和平均分结果都取整数。

请输入你的选择: 3
课程 1 总分 = 337 平均分 = 84
课程 2 总分 = 364 平均分 = 91
课程 3 总分 = 383 平均分 = 95

c7学生总分排序 如果a < b,则按升序排序。 选择菜单命令 4按选择法将数组sum的元素值按升序进行排序显示提示信息最后打印出学生信息。 如果a > b则按降序排序。选择菜单命令 5按选择法将数组sum的元素值按降序进行排序显示提示信息最后打印出学生成绩。

 请输入你的选择: 4
 按分数降序排序:
 2214111038 ZhangTongtong 100 95 86 281 93
 2214111018 LiYuxuan 85 91 98 274 91
 2214111026 MengTingyu 77 89 99 265 88
 2214111022 ZhouYufan 75 89 100 264 88
 请输入你的选择: 5
 按分数升序排列:
 2214111022 ZhouYufan 75 89 100 264 88
 2214111026 MengTingyu 77 89 99 265 88
 2214111018 LiYuxuan 85 91 98 274 91
 2214111038 ZhangTongtong 100 95 86 281 93

c8学号顺序排序 选择菜单命令 6按学号从小到大进行排序显示提示信息最后打印学生信息。

请输入你的选择: 6
按学号降序排列:
2214111018 LiYuxuan 85 91 98 274 91
2214111022 ZhouYufan 75 89 100 264 88
2214111026 MengTingyu 77 89 99 265 88 
2214111038 ZhangTongtong 100 95 86 281 93

C9: 姓名顺序排序 选择菜单命令 7 ,按姓名的字典顺序进行排序,显示提示信息,最后打印学生信息。

请输入你的选择: 7
按名称按字典顺序排序:
2214111018 LiYuxuan 75 89 100 264 88
2214111022 ZhouYufan 77 89 99 265 88
2214111026 MengTingyu 100 95 86 281 93
2214111038 ZhangTongtong 85 91 98 274 91

C10: 学生信息查询 选择菜单命令 8 ,提示输入学生学号,若该学号存在,则输出学生信息;否则提示没有找到并结束。

请输入你的选择: 8
输入你想搜寻的学号:2214111018
2214111018 LiYuxuan 75 89 100 264 88
1 输入成绩
2 计算每门课程的总分和平均分
3 计算每名学生的总分和平均分
4 按分数降序排序
5 按分数升序排序
6 按学号升序排序
7 按名称按字典顺序排序
8 按数字搜索
9 按名字搜索
10 统计分析
11 列表记录
12 写一个文件
13 从文件中读取
0  退出
请输入你的选择: 8
输入你想搜寻的学号:2214111001
没有找到!
选择菜单命令 9 ,提示输入学生姓名,若该姓名存在,则输出学生信息;否则提示没有找到并结束。
请输入你的选择: 9
输入你想搜寻的名字:ZhangTongtong
2214111038 ZhangTongtong 85 91 98 274 91
1 输入分数
2 计算每门课程的总分和平均分
3 计算每名学生的总分和平均分
4 按分数降序排序
5 按分数升序排序
6 按学号升序排序
7 按名称按字典顺序排序
8 通过学号搜索
9 通过姓名搜素
10 统计分析
11 列表记录
12 写一个文件
13 从文件中读取
0  退出
请输入你的选择: 9
请输入你想搜索的名字:GuoJiahui
Not found!

C11: 统计各分数段学生人数及所占百分比 选择菜单命令 10提示输入学生成绩通过循环得出各分数段学生人数及所占百分比

请输入你的选择: 10
关于课程1:
<60 0 0.00%
60-70 0 0.00%
70-80 2 50.00%
80-90 1 25.00%
90-100 0 0.00%
100 1 25.00%
For course 2:
<60 0 0.00%
60-70 0 0.00%
70-80 0 00.00%
80-90 2 50.00%
90-100 2 50.00%
100 0 0.00%
For course 3:
<60 0 0.00%
60-70 0 0.00%
70-80 0 0.00%
80-90 1 25.00%
90-100 2 50.00%
100 1 25.00%

C12: 打印学生信息 选择菜单命令11打印

请输入你的选择11
2214111018 李玉璇 100 95 86 281 93
2214111038 张桐桐 77 89 99 265 88
2214111026 孟婷玉 85 91 98 274 91
2214111022 周羽凡 75 89 100 264 88

C13: 将学生信息保存在文件中 选择菜单命令 12 ,将学生信息保存在文件 student.txt 中。如果文件不存在,则给出错误信息并退出程序,否则逐个读入

请输入你的选择12
未能打开你的成绩!
1 输入成绩
2 计算所有课程的总分和平均值
3 计算所有学生的总分和平均值
4 按分数降序排列
5 按分数升序排列
6 按数字升序排列
7 按名字字母排列
8 按数字搜索
9 按名字搜索
10 统计分析
11 列表记录
12 写入文件
13 从文件中读取
0 退出
请输入你的选择12
2214111018 李玉璇 100 95 86 281 93
2214111038 张桐桐 77 89 99 265 88
2214111026 孟婷玉 85 91 98 274 91
2214111022 周羽凡 75 89 100 264 88

C14从文件中读取学生信息 选择菜单命令 13 ,从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组 stu 中。如果文件为空,则给出错误信息并退出程序,反之,逐个读入

请输入你的选择13
未能打开你的成绩!
1 输入成绩
2 计算所有课程的总分和平均值
3 计算所有学生的总分和平均值
4 按分数降序排列
5 按分数升序排列
6 按数字升序排列
7 按名字字母排列
8 按数字搜索
9 按名字搜索
10 统计分析
11 列表记录
12 写入文件
13 从文件中读取
0 退出
请输入你的选择12
2214111018 李玉璇 100 95 86 281 93
2214111038 张桐桐 77 89 99 265 88
2214111026 孟婷玉 85 91 98 274 91
2214111022 周羽凡 75 89 100 264 88

概要设计

系统主要分为用户界面和数据处理两大模块。 用户界面模块包括输入学生成绩ReadScore、计算学生总分和平均分AverSumofEveryStudent、计算总分和平均分AverSumofEveryCourse、按选择发将数组元素排序Sortbyscore、使数据按升序排序Ascending、使数据按降序排序Descending、交换单精度浮点数据SwapFloat、交换长整型数据SwapLong、交字符串SwapChar、按选择法将数组元素按从低到高排序、交换实现字符串按字典顺序排序SortbyName、按学号查找学生成绩并显示查找结果SearchbyNum、按姓名的字典顺序排出成绩表 、统计各分数段的学生人数及所占的百分比 、打印学生成绩 、输出学生的学号、姓名及课程的成绩到文件student.txt中 、从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组stu中

上述各模块通过主程序main进行调用系统模块图如下。 添加库存记录流程图

各模块的主要功能如下:

main 系统主函数模块,显示菜单,根据用户选择的菜单命令,执行相关操作。

ReadScore 输入n个学生的m门课成绩

AverSumofEveryStudent 计算每个学生各门课程的总分和平均分

AverSumofEveryCourse 计算每门课程的总分和平均分

SortbyScore 按选择法将数组sum的元素值排序

Ascending 使数据按升序排序

Descending 使数据按降序排序

SwapFloat 交换两个单精度浮点型数据

SwapLong 交换两个长整型数据

SwapChar 交换两个字符串

AsSortbyNum 按选择法将数组num的元素值按从低到高排序

AsSortbyNum 交换法实现字符串按字典顺序排序

SearchbyNum 按学号查找学生成绩并显示查找结果

SearchbyName 按姓名的字典顺序排出成绩表

StatisticAnalysis 统计各分数段的学生人数及所占的百分比

PrintScore 打印学生成绩

WritetoFile 输出n个学生的学号、姓名及m门课程的成绩到文件student.txt中

ReadfromFile 从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组stu中

详细设计 针对概要设计

main

Step 1:初始化, Step 2:根据用户选择的命令执行相应的操作, Step 2.1:显示菜单, Step 2.2:选择菜单命令 c, Step 2.3:if c == 1 then ReadScore, Step 2.4:if c == 2 then AverSumofEveryStudent, Step 2.5:if c == 3 then AverSumofEveryCourse, Step 2.6:if c == 4 then SortbyScore(Descending), Step 2.7:if c == 5 then SortbyScore(Ascending), Step 2.8:if c == 6 then AsSortbyNum, Step 2.9:if c == 7 then SortbyName, Step 2.10:if c == 8 then SearchbyNum, Step 2.11:if c == 9 then SearchbyName, Step 2.12:if c == 10 then StatisticAnalysis, Step 2.13:if c == 11 then PrintScore, Step 2.14:if c == 12 then WritetoFile, Step 2.15:if c == 13 then ReadfromFile, Step 2.16:if c == 0 then exit,

详细设计

系统模块图

1·输入n个学生的m门课成绩
ReadScore
Step 1:显示提示信息,要求输入学生的学号,姓名和成绩
Step 2利用循环输入学生的学号成绩和各科成绩

n个学生的m门课成绩

2·计算每个学生各门课程的总分和平均分 
AverSumofEveryStudent
step1输入一门学生的成绩
step2将学生成绩相加输出总分
step3输出课程平均值
step4输入下一门课程

总分平均值

3·计算每门课程的总分和平均分 
AverSumofEveryCourse
step1输入第一门课程的所有学生的成绩
step2将成绩相加输出科目总分
step3总分/人数,输出课程平均分
step4输入下一个科目

课程总分平均分

4·按选择法将数组sum的元素值排序 
SortbyScore
Step 1:利用循环将i赋值给k
Step 2:用循环从i+1到n-1比较,将较小的赋给k
Step 3:如果k与i不相等每一课的成绩交换总分平均分学号姓名依次交换

lyx4

5.按选择法将数组num的元素值按从低到高排序

Step 1:利用 for 循环给 i 赋值为0
Step 2:利用 if 条件判断学号是否致
Step 3:利用二次循环找出所有符合条件件的学
Step 4:利用 i 件语句能否找到该学生

排序1

6.交换法实现字符串按字典顺序排序

step 1:利用for循环将相邻的两个姓名作比较
step 2:如果前一个字符串大于后一个利用for循环交换m门课程的成绩
step 3:依次交换

排序2

7.按学号查找学生成绩并显示查找结果

Step 1:利用for循环给i赋值为0
Step 2:利用if条件判断学号是否一致
Step 3:利用二次循环找出所有符合条件的学生
Step 4利用if条件语句能否找到该学生

查找

8.按姓名的字典顺序排出成绩表

Step 1:利用for循环给i赋值为0
Step 2:利用of条件语句和循环判断是否此学生并显示结果

排序3

9·统计各分数段的学生人数及所占的百分比

StatisticAnalysis
step1:输入每个学生的成绩
step2:判断输入成绩所在的分数段
step3:将各个分数段的成绩个数除以学生总人数并乘以百分百

统计

10·打印学生成绩

PrintScore
step1:输入学生的学号,姓名.
step2:查找该学生的成绩
step3:输出该学生的成绩

打印

11·输出n个学生的学号、姓名及m门课程的成绩到文件student.txt中

WritetoFile
step1:输入学生的学号和姓名
step2:查找该学生的所有课程成绩
step3:将成绩保存到文件student.txt中

文件

12·从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组stu中

ReadfromFile
step1:查找文件
step2:从文件中读取学生的学号姓名成绩
step3:将信息写入到数组stu中

stu

总结思考

张桐桐 在这次项目的活动中,我体会到了团队合作的高效和包容,利用看板去分配任务,将一个大项目分成多个大问题,然后再把大问题分成一个一个的小问题,每完成一个小问题都在向目标前进一步,不仅降低了难度也提高了组员们自信和成就感。将每个任务分配到个人,不仅赋予使命,也有其他成员对其进行测试,让每个分支任务可以更好的进行。本次团队合作让我认识到作为一个管理者需要一个对问题的大局观念,如何去分配任务,如何去与队友进行有效的沟通,如何把控项目的进度,这些都让我在此次项目中学到很多。 李玉璇 通过本次项目,我学到了团队合作的重要性,知道了团队之间合作完成一个项目的过程是需要配合和分工,通过分工将大的工作分成细小的模块,在看板上呈现出一个个任务点的进行,让我有种提前进入工作的感受。在以后的工作当中这也是不可缺少的一部分,这也给我了一种全新的体验。与团队的沟通也是极其重要的,每个人都对自己的任务部分负责,让进度更好的往下一步进行,使得任务更快的完成。我在这个项目不仅仅时学会了工作中的合作更多的还是对分配的任务进行较好的处理,提高了效率和责任感,这是一次有意义有收获的项目合作活动。