学生成绩管理系统 (3).doc

上传人:精*** 文档编号:859870 上传时间:2023-09-23 格式:DOC 页数:23 大小:236.73KB
下载 相关 举报
学生成绩管理系统 (3).doc_第1页
第1页 / 共23页
学生成绩管理系统 (3).doc_第2页
第2页 / 共23页
学生成绩管理系统 (3).doc_第3页
第3页 / 共23页
学生成绩管理系统 (3).doc_第4页
第4页 / 共23页
学生成绩管理系统 (3).doc_第5页
第5页 / 共23页
点击查看更多>>
资源描述

1、目 录1、需求分析1 1.1课程设计题目及要求1 1.2课程设计思想1212、概要设计23、详细设计3 3.1 文件合并33.2 自动检索33.3 数据排序43.4 信息查询54、调试分析和测试结果75、总结126、致谢137、附录14参考文献201、需求分析1.1课程设计题目及要求题目:学生成绩管理系统现有学生成绩信息文件1(1.txt),内容如下姓名 学号 语文 数学 英语 张明明 01 67 78 82李成友 02 78 91 88张辉灿 03 68 82 56王露 04 56 45 77陈东明 05 67 38 47. . . . 学生成绩信息文件2(2.txt),内容如下:姓名 学号

2、 语文 数学 英语 陈果 31 57 68 82李华明 32 88 90 68张明东 33 48 42 56李明国 34 50 45 87陈道亮 35 47 58 77. . . . 试编写一管理系统,要求如下:1、 实现对两个文件数据进行合并,生成新文件3.txt2、 抽取出三科成绩中有补考的学生并保存在一个新文件4.txt3、 对合并后的文件3.txt中的数据按总分降序排序4、 输入一个学生姓名后,能查找到此学生的信息并输出结果5、 要求使用结构体,链或数组等实现上述要求.采用多种方法且算法正确者,可适当加分.1.2课程设计思想本课题的实质是完成对学生成绩表的合并、提取、排序查询等功能,可

3、以首先定义项目的数据结构,然后将每个功能写成一个函数来完成对数据的操作,最后完成主函数以验证各个函数功能并得出运行结果。可将此系统分为如下模块,合并两个信息表、从表中提取信息、降序排序模块、按条件查询、退出系统。2、概要设计(1)总体方案 文件合并信息查询学生成绩管理系统自动检索数据排序 退出系统 系统菜单合并两个信息表 提取信息降序排序查询信息(2)流程3、详细设计 3.1 文件合并已知:文件1.txt、文件2.txt、id、name、chinese、math、english。求:调用函数来实现 1.txt和2.txt合并为新生成文件3.txt算法:1.函数以读的方式打开1.txt文件和2.

4、txt文件,以写的方式打开3.txt文件; 2.从1.txt读入一个数据并写入3.txt文件,直到遇到1.txt文件结束; 3.用上述方式把数据写入3.txt直到遇到2.txt文件结束; 4.关闭1.txt,2.txt,3.txt文件,实现对于文件的合并。核心程序:void Unitedfile() /*合并1.txt和2.txt为3.txt*/FILE *fp,*p;Student studd;fp=fopen(1.txt,r); /*以读的方式打开1.txt*/p=fopen(3.txt,w); /*以写的方式打开3.txt*/ fscanf(fp,%*n%*c); /*跳过一行字符串*/

5、fprintf(p,姓名 学号 语文 数学 英语 n); while(fscanf(fp,%s%d%d%d%d,studd.name,&studd.id,&studd.chinese,&studd.math,&studd.english )!=EOF)fprintf(p,%-6s %2d %d %d %dn,studd.name,studd.id,studd.chinese,studd.math,studd.english ); /*读取1.txt的数据进入结构体中,写入3.txt,继续读取直结束*/fclose(fp); /*关闭文件1.txt*/fp=fopen(2.txt,r); /*以

6、写的方式打开2.txt*/fscanf(fp,%*n%*c); /*跳过一行字符串*/while(fscanf(fp,%s%d%d%d%d,studd.name,&studd.id,&studd.chinese,&studd.math,&studd.english )!=EOF)fprintf(p,%-6s %2d %d %d %dn,studd.name,studd.id,studd.chinese,studd.math,studd.english ); /*读取2.txt的数据进入结构体中,写入3.txt,继续读取直结束*/ fclose(fp); /*关闭文件2.txt*/fclose(

7、p); /*关闭文件3.txt*/3.2 自动检索已知:文件3.txt、id、name、chinese、math、english。求:chinese、math、english中小于60的成绩,并显示名字、学号。算法:1.读取3.txt; 2.创建4.txt;3.读取3.txt里面的成绩,应用studd.chinese60|stud.english60|stud.math60找出不及格的成绩; 4.将不及格成绩写入4.txt; 5.关闭3.txt;4.txt。核心程序:void findout() /*抽取出三科成绩中有补考的学生并保存在一个新文件4.txt*/FILE *fp,*p;Stude

8、nt studd;fp=fopen(3.txt,r); /*以读的方式打开3.txt*/p=fopen(4.txt,w); /*以写的方式打开4.txt*/fscanf(fp,%*n%*c); /*跳过一行字符串*/fprintf(p,姓名 学号 语文 数学 英语n); while(fscanf(fp,%s%d%d%d%d,studd.name,&studd.id,&studd.chinese,&studd.math,&studd.english )!=EOF)if(studd.chinese60|studd.english60|studd.math60)fprintf(p,%-6s %2d

9、%d %d %dn,studd.name,studd.id,studd.chinese,studd.math,studd.english ); /*从3.txt中读入学生数据进结构体,判断是否有不及格的课程,如果有,则写入文件4.txt中*/fclose(fp); /*关闭文件3.txt*/fclose(p); /*关闭文件4.txt*/3.3 数据排序已知:文件3txt 、id、name、chinese、math、english。求:各个学生的总分并按照降序排序算法:1.读取3.txt; 2.求出文件3.txt各个学生的总分; 3.用选择排序的方法将学生的总分进行排序; 4.关闭文件3.tx

10、t。核心程序:void Selectsort() /*对合并后的文件3.txt中的数据按总分降序排序*/int j,k,max1,sum1,sum2,q;i=0;Student temp;FILE *fp;fp=fopen(3.txt,r); /*以读的方式打开3.txt*/i=0;fscanf(fp,%*n%*c); /*跳过一行字符串*/while(fscanf(fp,%s%d%d%d%d,studi.name,&studi.id,&studi.chinese,&studi.math,&studi.english )!=EOF)i+; /*从3.txt中读入数据进结构体数组stud中*/f

11、close(fp);for(j=0;ji;j+) /*对结构体数组中的数据进行选择排序*/ /*每趟是选出一个最值确定其在结果序列中的位置,确定元素的位置是从前往后,而每趟最多进行一次交换,其余元素的相对位置不变。可进行降序排序*/max1=j;sum1=studj.math+studj.english+studj.chinese;for(k=j+1;ki+1;k+)sum2=studk.math+studk.english+studk.chinese;if(sum1sum2)max1=k;sum1=sum2;if(max1!=j)temp=studmax1;studmax1=studj;st

12、udj=temp;studj.sum=sum1;fp=fopen(3.txt,w); /*将排序后的数据写入3.txt中*/fprintf(fp,姓名 学号 语文 数学 英语 总分n);for(q=0;qNAME;while(fscanf(fp,%s%d%d%d%d%d,stud1.name,&stud1.id,&stud1.chinese,&stud1.math,&stud1.english,&stud1.sum )!=EOF)if(strcmp(stud1.name,NAME)=0) /*如果输入的姓名达到要求*/ /*输出显示其相对应的信息*/flag=1;cout-姓名-学号-语文-数

13、学-英语-总分-endl;cout stud1.name stud1.id ;coutstud1.chinese stud1.math stud1.english stud1.sumendl;break;if(flag=0) cout无此学生相关信息endl; /*如无法找到,则显示无此学生相关信息*/fclose(fp); /*关闭文件3.txt*/4、调试分析和测试结果系统各功能的运行时界面及使用说明:(1)建立两个文本文件1.txt、2.txt 图4.1 1.txt图4.2 2.txt(2)主菜单界面图4.3 主菜单界面(3)输入1合并1.txt和2.txt生成3.txt图4.4图4.5

14、 3.txt(4)输入2抽取出三科成绩中有补考的学生并保存在新文件4.txt中图4.6图4.7 4.txt(5)输入3,对合并后的文件3.txt中的数据进行排序图4.8图4.9 排序后的3.txt(6)输入4,再输入所要查找学生的姓名进行查找图4.10(7)继续查找就输入Y否则就输入N5、总结通过这次课程设计使我对数据结构这门课程有了更深的认识和理解,也使我更加明白一门编程语言在软件开发中的重要性和地位。课程设计是培养学生综合运用所学知识 ,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对我们的实际工作能力的具体训练和考察过程.随着科学技术发展的日新月异,当今计算机应用在生活中可以

15、说得是无处不在。因此作为二十一世纪的大学来说掌握程序开发技术是十分重要的。这几天的课程设计学习使我们懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正为社会服务,从而提高自己的实际动手能力和独立思考的能力。在设计的过程中遇到问题,可以说得是困难重重,在设计的过程中发现了自己的不足之处,对一些前面学过的知识理解得不够深刻,掌握得不够牢固,通过这次课程设计之后,我把前面所学过的知识又重新温故了一遍。我做的是学生成绩管理系统的课程设计,虽然是很简单的一个小的程序,但对我来说却是一个很大的困难。因为对数据结构不是很会,所以做了一

16、个下午却丝毫没有进展,最主要是不知从何开始,这个时候才知道上课老师们不厌其烦的教导是多么的宝贵,这个时候才后悔上课的时候没有认真的听讲。可是现在一切都晚了,还好时间还算是充裕,只好拿出书本重新复习一下。开始的时候真的感觉编程是一件很无聊的事情,不过当一个程序运行成功的时候那种喜悦是无法言语的,那种成就感是无法比拟的。又经过几天的努力,终于把程序完成了,尽管程序还是有很多功能上的欠缺和漏洞,可我还是很高兴的。无论如何是自己的劳动成果,是自己经过努力得到的成绩,同时也是学习数据结构的一次实践作业,自己进步的证明。在课程设计过程中,收获知识,提高能力的同时,我也学到了很多人生的哲理,懂得怎么样去制定

17、计划,怎么样去实现这个计划,并掌握了在执行过程中怎么样去克服心理上的不良情绪。因此在以后的生活和学习的过程中,我一定会把课程设计的精神带到生活中,不畏艰难,勇往直前!6、致谢因为初次接触数据结构课程设计和基础不扎实的原因,在此次课程设计中我遇到了许多问题,我深刻体会到合作的重要性, 数据结构程序对我来说比较难,在匆忙的学习中更是难上加难,似乎觉得自己仅是个匆匆过客,但在同学的帮助下我学会了如何调试,如何查找系统没有提示的错误,最后终于排除万难把程序搞定,体会到原来编程也挺有意思的快感.我想没有同学的帮助仅靠我自己是很难在短期内把程序设计做的这样好,在此特地感谢我的小组成员的帮助。8、附录程序源

18、码#includeusing namespace std;#define SIZE 100 /*存放学生数据的结构体*/typedef struct char name10;int id;int chinese;int math;int english;int sum;Student;Student studSIZE;int i;int sign=0,sign1=0,sign2=0,sign3=0;void Unitedfile() /*合并1.txt和2.txt为3.txt*/FILE *fp,*p;Student studd;fp=fopen(1.txt,r); /*以读的方式打开1.tx

19、t*/p=fopen(3.txt,w); /*以写的方式打开3.txt*/ fscanf(fp,%*n%*c); /*跳过一行字符串*/fprintf(p,姓名 学号 语文 数学 英语 n); while(fscanf(fp,%s%d%d%d%d,studd.name,&studd.id,&studd.chinese,&studd.math,&studd.english )!=EOF)fprintf(p,%-6s %2d %d %d %dn,studd.name,studd.id,studd.chinese,studd.math,studd.english ); /*读取1.txt的数据进入结

20、构体中,写入3.txt,继续读取直结束*/fclose(fp); /*关闭文件1.txt*/fp=fopen(2.txt,r); /*以写的方式打开2.txt*/fscanf(fp,%*n%*c); /*跳过一行字符串*/while(fscanf(fp,%s%d%d%d%d,studd.name,&studd.id,&studd.chinese,&studd.math,&studd.english )!=EOF)fprintf(p,%-6s %2d %d %d %dn,studd.name,studd.id,studd.chinese,studd.math,studd.english ); /

21、*读取2.txt的数据进入结构体中,写入3.txt,继续读取直结束*/ fclose(fp); /*关闭文件2.txt*/fclose(p); /*关闭文件3.txt*/void findout() /*抽取出三科成绩中有补考的学生并保存在一个新文件4.txt*/FILE *fp,*p;Student studd;fp=fopen(3.txt,r); /*以读的方式打开3.txt*/p=fopen(4.txt,w); /*以写的方式打开4.txt*/fscanf(fp,%*n%*c); /*跳过一行字符串*/fprintf(p,姓名 学号 语文 数学 英语n); while(fscanf(fp

22、,%s%d%d%d%d,studd.name,&studd.id,&studd.chinese,&studd.math,&studd.english )!=EOF)if(studd.chinese60|studd.english60|studd.math60)fprintf(p,%-6s %2d %d %d %dn,studd.name,studd.id,studd.chinese,studd.math,studd.english ); /*从3.txt中读入学生数据进结构体,判断是否有不及格的课程,如果有,则写入文件4.txt中*/fclose(fp); /*关闭文件3.txt*/fclos

23、e(p); /*关闭文件4.txt*/void Selectsort() /*对合并后的文件3.txt中的数据按总分降序排序*/int j,k,max1,sum1,sum2,q;i=0;Student temp;FILE *fp;fp=fopen(3.txt,r); /*以读的方式打开3.txt*/i=0;fscanf(fp,%*n%*c); /*跳过一行字符串*/while(fscanf(fp,%s%d%d%d%d,studi.name,&studi.id,&studi.chinese,&studi.math,&studi.english )!=EOF)i+; /*从3.txt中读入数据进结

24、构体数组stud中*/fclose(fp);for(j=0;ji;j+) /*对结构体数组中的数据进行选择排序*/ /*每趟是选出一个最值确定其在结果序列中的位置,确定元素的位置是从前往后,而每趟最多进行一次交换,其余元素的相对位置不变。可进行降序排序*/max1=j;sum1=studj.math+studj.english+studj.chinese;for(k=j+1;ki+1;k+)sum2=studk.math+studk.english+studk.chinese;if(sum1sum2)max1=k;sum1=sum2;if(max1!=j)temp=studmax1;studm

25、ax1=studj;studj=temp;studj.sum=sum1;fp=fopen(3.txt,w); /*将排序后的数据写入3.txt中*/fprintf(fp,姓名 学号 语文 数学 英语 总分n);for(q=0;qNAME;while(fscanf(fp,%s%d%d%d%d%d,stud1.name,&stud1.id,&stud1.chinese,&stud1.math,&stud1.english,&stud1.sum )!=EOF)if(strcmp(stud1.name,NAME)=0) /*如果输入的姓名达到要求*/ /*输出显示其相对应的信息*/flag=1;cou

26、t-姓名-学号-语文-数学-英语-总分-endl;cout stud1.name stud1.id ;coutstud1.chinese stud1.math stud1.english stud1.sumendl;break;if(flag=0) cout无此学生相关信息endl; /*如无法找到,则显示无此学生相关信息*/fclose(fp); /*关闭文件3.txt*/*主程序*/ int main() int choice; while(1) /*主菜单*/if(sign3=0)printf(-学生成绩管理系统-n);printf(1. 合并1.txt和2.txt为3.txtn); p

27、rintf(2. 抽取出三科成绩中有补考的学生并保存在一个新文件4.txtn); printf(3. 对合并后的文件3.txt中的数据按总分降序排序n); printf(4. 输入一个学生姓名,查找到此学生的信息并输出结果n);printf(5. 退出n);printf(请选择(1-5):); sign3=1;scanf(%d,&choice); /*输入功能数字,颜色按照定义颜色*/switch(choice) case 1: Unitedfile();sign=1;cout操作1成功!endl;break; /*输入1,使用Unitedfile函数。并显示操作1成功!*/case 2: if(sign=0)cout请执行操作1后再执行此项操作!endl;break;cout操作2成功!endl;findout();break; /*输入2,如果sign=0输出请执行操作1后再执行此项操作!。否则输出操作2成功!*/case 3:if(sign=0)cout请执行操作1后再执行此项操作!endl;break;Selectsort();cout操作3成功!endl;sign1=1;break; /*输入3,如果sign=0输出请执行操作1后再执行此项

展开阅读全文
相关资源
相关搜索
资源标签

当前位置:首页 > 学术论文 > 毕业设计

版权声明:以上文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如有侵权请立即联系:2622162128@qq.com ,我们立即下架或删除。

Copyright© 2022-2024 www.wodocx.com ,All Rights Reserved |陕ICP备19002583号-1 

陕公网安备 61072602000132号     违法和不良信息举报:0916-4228922