版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、x x 航 空 工 业 学 院 课程设计学 号 _班 级 _ 姓 名 _指导教师 _年 月 日xx航空工业学院课程设计任务书机械与汽车学院 机械设计制造及其自动化专业 5406108班 学号200504061267一、课程设计题目:班级学生成绩管理二、课程设计工作自2007年7月9日起至2007年7月14日止三、课程设计内容:运用所学的c语言知识,编制和调试程序,具体要求如下:(1) 添加学生数据(2) 删除学生数据(3) 按总成绩排序,并显示名次(成绩相同,名次相同)(4) 成绩查询(5) 自己再加一项功能注:每个学生数据至少应该包括学号、姓名、三门成绩,学生数据要保存在student.da
2、t文件中。四、课程设计要求:1、采用模块化程序设计方法;在程序界面,以菜单的形式调用各功能函数;程序可读性强,界面友好;输出形式尽量美观。2、用户界面友好,功能明确,操作方便;可以加以其它功能或修饰。3、用户界面中的菜单至少应包括“输入数据”、“删除数据”、“排序”、“查询”、“退出”5项。4、代码应适当缩进,并给出必要的注释,以增强程序的可读性。课程设计说明书:课程结束后,上交课程设计说明书(打印稿和电子稿),其内容如下:l 封面l 课程设计任务书l 目录l 需求分析(分析题目的要求)l 程序流程图(总体流程图和主要功能模块流程图)l 核心技术的实现说明及相应程序段l 个人总结l 参考资料l
3、 源程序及适当的注释指导教师:_学生签名:_沈 阳 航 院 设 计 用 纸目录一、需求分析1二、程序流程图2三、核心技术的实现说明及相应程序段7四、个人总结13五、参考文献14六、源程序1421一、需求分析经过对程序设计题目的分析可知,整个程序的设计实现大致分为五个模块,其中每一个模块对应一个函数,他们的功能分别是:添加学生数据函数(add),删除数据函数(del),排序函数(sort),成绩查询函数(query),以及更改学生数据函数(change)。在这些函数当中,前四个函数的实现严格按照题目的要求,而后面的一个函数属于附加功能。1、添加学生数据函数 主要实现程序最初运行时学生数据的录入以
4、及其后的运行中学生数据的追加功能;2、删除学生数据函数 实现的功能是按照学号对学生的数据记录进行删除;3、排序函数 按照题目的具体要求实现的是总成绩的递减排序以及名次显示,其中总成绩相同者名次相同;4、成绩查询函数 允许按照学号对学生的各科成绩进行查询;5、更改数据函数 可以实现对学生记录中除学号以外的信息进行修改;除上面介绍的功能之外,程序还具有退出功能,可以在程序的一次运行当中循环执行所有的功能,并根据需要终止程序的执行。每一个学生记录都包含学号、姓名,以及英语、计算机和数学三门成绩,在程序当中,将学生记录类型定义为结构体类型,添加以及追加的学生信息直接写入e盘的student.dat文件
5、中,其他函数每次对学生记录的访问,其数据来源都是student.dat文件,这样做不但可以保证学生数据的一致性,而且可以对学生数据进行永久保存,保证每次运行程序都可以采用原来的数据。二、程序流程图1、程序总体结构图 当(1) 真 n=1 假 添加 n=2? 数据 真 假 函数 n=3? add( ) 删除 真 假 函数 del() 排序 真 n=4? 假 sort() 查询 n=5?check() 真 假 更改 退出change() 图1程序总体结构图2、具体功能框图(1)添加学生数据函数add 读写方式打开e盘student.dat文件不成功?真 假写方式打开e盘student.dat文件不
6、成功 ? 输入追加的学生数量n真 假 读出学生记录数量赋j输出文件打开失败 输入录入学生数量n 文件位置指针重回开头rewind将n值写如文件 学生记录总数n+j写入文件循环变量i=1 文件位置指针定位在结尾fseek当i=n时 循环变量i=1return; 输入学号,姓名和 当i=n时三门成绩 输入学号,姓名和三门成绩学生信息写入文件i+ 学生信息写入文件i+关闭文件 图2 添加学生数据函数(2)读取学生数据reads循环变量i=0i*n读出一条学生记录到形参数组元素stui读出记录总数赋给形参*n开始i+关闭文件结束读方式打开e盘student.dat文件不成功?returnnnyy图3读
7、取学生数据(3)删除学生记录函数delreads(stu,&n);循环变量i=0; 输入待删除的学生学号number假i+当in-1时stui与number相等?真break;输出该学生记录不存在!记录写回文件i+关闭文件return;当i=n-2显示打开文件失败!i=0写方式打开student.dat不成功?假真数租元素依次前移 j+当j=n?真假j=i+1(4)按总分排序函数sort(4)排序函数sort图4删除学生记录函数(4)按总分排序函数sort 循环变量i=o,j=oreads(stu.&n);当i=n-1当jn-1-i第j个学生总分第j+1个总分真 假交换两个学生信息j+ j+i
8、+ 写方式打开e盘student.dat文件成功真 假记录总数n写入文件 显示打开文件失败!i=0当in写入文件并输出,输出时显示名次i+ return;关闭文件图5总分排序函数三、核心技术的实现说明及相应程序段本程序主要由五个自定义函数和一个主函数组成,其中主函数以菜单的形式调用其他函数来实现要求的所有功能。在这些函数当中,添加数据函数、删除数据函数和排序函数是程序中较为核心的部分,下面分别进行说明。1、添加数据函数 添加数据分为两种情况,其一是在学生文件(student.dat)不存在的情况下,首先由程序创建一个新文件,并将录入的学生信息写入该文件当中;其二是在学生文件(student.d
9、at)已经存在的情况下,此时文件要以读写方式或追加的方式打开,这样才可以保证以前已经存在的数据不丢失。具体的程序段如下:if(fp=fopen(e:student.dat,rb+)!=null) /*读写方式打开文件*/ j=getw(fp); rewind(fp); /*文件位置指针返回文件开头*/ printf(请输入要添加的学生数量,按回车键确认:); scanf(%d,&n); putw(j+n,fp); fseek(fp,0l,2); for(i=1;i=n;i+) printf(n请输入第%d个学生的学号、姓名,并按回车键确认:n,i); scanf(%s%s,stu.num,st
10、); printf(n请输入第%d个学生的三门成绩,并按回车键确认:n,i); scanf(%f%f%f,&stu.english,&puter,&stu.math); fwrite(&stu,sizeof(struct student),1,fp); else /*文件不存在时,新建一个文件,并将数据写入该文件*/ if(fp=fopen(e:student.dat,wb)!=null) printf(请输入要添加的学生数量,按回车键确认:); scanf(%d,&n); putw(n,fp); for(i=1;i=n;i+) printf(n请输入第%d个学生的学号、姓名,并按
11、回车键确认:n,i); scanf(%s%s,stu.num,); printf(n请输入第%d个学生的三门成绩,并按回车键确认:n,i); scanf(%f%f%f,&stu.english,&puter,&stu.math); fwrite(&stu,sizeof(struct student),1,fp); fclose(fp);2、删除数据函数该函数的核心内容是删除算法以及最终对源文件的更新。该函数执行时,首先调用reads函数将文件中的学生信息读入数组当中,并由用户输入待删除学生的学号,而后按照该学号进行查找,如果文件中存在该学生的数据,则采用删除算法删除,否则输出学
12、生信息不存在的提示信息。对学生信息的具体删除算法是在结构体数组中实现的,当学生的信息被找到后,位于数组中该学生后面的学生记录依次向前移动一个元素的位置,这些操作完成后,要删除的学生信息就被后面的数组元素覆盖掉了,也就实现了删除。在数组中删除学生信息后,还要将更改后的信息重新写回文件当中,以保证数据的一致性。具体程序段如下:void del() /*信息删除函数*/struct student stun; char number20; file *fp; int n,i,j; reads(stu,&n); printf(n请输入要删除信息的学生学号,按回车键确认:); scanf(%s,numb
13、er); for(i=0;i=n) printf(没有找到该学生信息!n); return; elsefor(j=i+1;jn;j+) /*左移,覆盖待删除的学生记录*/ strcpy(stuj-1.num,stuj.num); strcpy(,); stuj-1.english=stuj.english; puter=puter; stuj-1.math=stuj.math; if(fp=fopen(e:student.dat,wb)=null) printf(文件打开失败!); return; else /*重新写
14、回文件当中*/ putw(n-1,fp); for(i=0;in-1;i+) fwrite(&stui,sizeof(struct student),1,fp); fclose(fp); printf(删除成功!n);3、总分排序函数对于总分的排序采用的排序算法是冒泡法排序,其中总分的求得是在排序的过程中实现的,这部分程序仍然调用了reads函数,整个排序过程在结构体数组stu中实现,由于排序算法涉及到两个数组元素的信息交换,因此还需要定义一个中间变量来协助。排序函数使学生数据的排列顺序发生了变化,因此也需要队员文件进行更新,此外,对于学生排序后名次的确定,仅在结果输出时予以显示,并未将名次信
15、息写入源文件。具体的程序段如下:void sort()/*排序函数*/ file *fp; struct student stun,temp; int i,j,n; reads(stu,&n); for(i=0;in-1;i+) for(j=0;jn-1-i;j+) if(stuj.english+puter+stuj.mathstuj+1.english+stuj+1.computer+stuj+1.math) strcpy(temp.num,stuj.num); strcpy(,); temp.english=stuj.english;
16、puter=puter; temp.math=stuj.math; strcpy(stuj.num,stuj+1.num); strcpy(,stuj+1.name); stuj.english=stuj+1.english; puter=stuj+1.computer; stuj.math=stuj+1.math; strcpy(stuj+1.num,temp.num); strcpy(stuj+1.name,); stuj+1.english=temp.english; stuj+1.computer=puter; stu
17、j+1.math=temp.math; if(fp=fopen(e:student.dat,wb)=null) /*更新文件*/ printf(打开文件失败!); return; putw(n,fp); j=1; for(i=0;in;i+) fwrite(&stui,sizeof(struct student),1,fp);if(stui.english+puter+stui.math=stui+1.english+stui+1.computer+stui+1.math) printf(%3d%5s%5s%8.2f%8.2f%8.2f%9.2fn,j,stui.num,stu
18、,stui.english,puter,stui.math,stui.english+puter+stui.math);else printf(%3d%5s%5s%8.2f%8.2f%8.2f%9.2fn,j+,stui.num,,stui.english,puter,stui.math,stui.english+puter+stui.math); fclose(fp);getch();四、个人总结通过这次课设我对c语言的掌握比以前熟练了很多,也学会了严谨的治学态度。以前对“c语言”的认识就是以为这是
19、一门学校开设的学科,首先不能挂科,其次要学好它,至于它有什么用处,感受并不是深。本次课设,就是一个把所学知识与生活实践完美结合的典范。课设让我们知道了所学的知识大有用武之地,从而更加激发我学习“c语言”的热情。这次课程设计考察了多方面的知识,比如结构体、文件等等,使我们熟练的掌握知识的同时还增强了我们的实际动手的能力。有时候我个人的能力是有限的,必要是要接受别人的帮助。五、参考文献1 谭浩强c程序设计北京:清华大学出版社,20052 刘成等c语言程序设计实验指导与习题集北京:中国铁道出版社,2006六、源程序#include#include#define n 20struct studentc
20、har num20; char name10; float english; float computer; float math;void menu();void reads();void add();void del();void sort();void check();void change();void exit();main() int n; while(1) menu(); printf(n qingshuruninyaoxuanzedecaozuoxuhaoanhuichequeren); scanf(%d,&n); switch(n) case 1: add();break;
21、case 2: del();break; case 3: sort();break; case 4: check();break; case 5: change();break; case 6: exit(0); default: printf(shurucuowuqingshurulinbiaozhongcunzaidexuhaon ); void menu()printf( * banjichangjiguanlixitong* ); printf(n 1 tianjiaxueshengshuju); printf(n 2 shanchuxueshengshuju); printf(n 3
22、 genggaixueshengshuju); printf(n 4 zongchengjipaixu); printf(n 5 chengjichaxun); printf(n 6 tuichu);void reads(struct student stun,int *n) file *fp; int i=0; if(fp=fopen(e:student.dat,rb)=null) printf(wenjiandakaishibain); return; else *n=getw(fp); for(i=0;i*n;i+) fread(&stui,sizeof(struct student),
23、1,fp); fclose(fp);void add()file *fp; int n,i,j; struct student stu; if(fp=fopen(e:student.dat,rb+)!=null) j=getw(fp); rewind(fp); printf(qingshuruyaotianjiadexueshengshulianganhuichequeren); scanf(%d,&n); putw(j+n,fp); fseek(fp,0l,2); for(i=1;i=n;i+) printf(nqingshurudi%dgexueshengdexuehaoxingmingy
24、ongkonggefengkaibinganhuichequerenn,i); scanf(%s%s,stu.num,); printf(nqingshurudi%dgexueshengdeyingyujisuanjiheshuxuedesanmenchengjiyongkonggefengkaibinganhuichejianquerenn,i); scanf(%f%f%f,&stu.english,&puter,&stu.math); fwrite(&stu,sizeof(struct student),1,fp); else if(fp=fopen(e:student.d
25、at,wb)!=null) printf(qingshuruyaotianjiadexueshengshulianganhuichejianqueren); scanf(%d,&n); putw(n,fp); for(i=1;i=n;i+) printf(nqingshurudi%dgexueshengdexuehaoxingmingyongkonggefenkaibinganhuichejianquerenn,i); scanf(%s%s,stu.num,); printf(nqingshurudi%dgexueshengdeyingyujisuanjiheshuxuesan
26、menchengjiyongkonggefenkaibinganhuichejianquerenn,i); scanf(%f%f%f,&stu.english,&puter,&stu.math); fwrite(&stu,sizeof(struct student),1,fp); fclose(fp);void del() struct student stun; char number20; file *fp; int n,i,j; reads(stu,&n); printf(nqingshuruyaoshanchuxueshengxinxidexueshengxuehaoanhuichej
27、ianqueren); getchar(); scanf(%s,number); for(i=0;i=n) printf(meiyouzhaodaogaixueshengxinxin); return; elsefor(j=i+1;jn;j+) strcpy(stuj-1.num,stuj.num); strcpy(,); stuj-1.english=stuj.english; puter=puter; stuj-1.math=stuj.math; if(fp=fopen(e:student.dat,wb)=null
28、) printf(wenjiandakaishibai); return; else putw(n-1,fp); for(i=0;in-1;i+) fwrite(&stui,sizeof(struct student),1,fp); fclose(fp); printf(shanchuchenggongn);void sort() file *fp; struct student stun,temp; int i,j,n; reads(stu,&n); for(i=0;in-1;i+) for(j=0;jn-1-i;j+) if(stuj.english+puter+stuj.
29、mathstuj+1.english+stuj+1.computer+stuj+1.math) strcpy(temp.num,stuj.num); strcpy(,); temp.english=stuj.english; puter=puter; temp.math=stuj.math; strcpy(stuj.num,stuj+1.num); strcpy(,stuj+1.name); stuj.english=stuj+1.english; puter=stuj+1.computer; stuj.ma
30、th=stuj+1.math; strcpy(stuj+1.num,temp.num); strcpy(stuj+1.name,); stuj+1.english=temp.english; stuj+1.computer=puter; stuj+1.math=temp.math; if(fp=fopen(e:student.dat,wb)=null) printf(dakaiwenjianshibai); return; putw(n,fp); j=1; for(i=0;in;i+) fwrite(&stui,sizeof(struct student),1,fp); if
31、(stui.english+puter+stui.math=stui+1.english+stui+1.computer+stui+1.math) printf(n%3d%5s%5s%8.2f%8.2f%8.2f%9.2fn,j,stui.num,,stui.english,puter,stui.math,stui.english+puter+stui.math); else printf(n%3d%5s%5s%8.2f%8.2f%8.2f%9.2fn,j+,stui.num,,stui.english,puter,stui
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论