数据结构课程设计学生籍贯管理系统_第1页
数据结构课程设计学生籍贯管理系统_第2页
数据结构课程设计学生籍贯管理系统_第3页
数据结构课程设计学生籍贯管理系统_第4页
数据结构课程设计学生籍贯管理系统_第5页
已阅读5页,还剩16页未读 继续免费阅读

付费下载

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、数据结构课程设计报告学号1208210115 2014-2015学年 第一学期数据结构课程设计报告题目:学生籍贯管理系统专业:计算机科学与技术(对口)班级:12级(3)班姓名:胡晓芳指导教师:陈广宏成绩:计算机与信息工程系2014 年 12月 15 日目录1设计内容及要求11.1课程设计要求11.2 学生籍贯管理系统的要求12 设计思想13系统完成功能及功能框图25、保存功能:将学生记录保存到任何自定义的文件中。24界面设计34.1主界面:34.2 显示已经存入的学生籍贯信息记录34.3 删除学生记录界面44.4 修改学生籍贯界面44.5 查询显示所有上海籍的学生54.6 显示天津籍跟非天津籍

2、的学生54.7 此次学生籍贯管理系统公共数据结构如下:65 小结6参考文献7附录:程序源代码8课程设计报告内容1设计内容及要求1.1课程设计要求1. 要求利用C语言面向过程的编程思想来完成系统的设计; 2. 突出C语言的函数特征,以多个函数实现每一个子功能; 3. 画出功能模块图; 4. 进行简单界面设计,能够实现友好的交互; 5. 具有清晰的程序流程图和数据结构的详细定义; 6. 熟练掌握C语言对文件的各种操作。1.2 学生籍贯管理系统的要求该程序应该具有下列功能:(1) 输入学生信息并以磁盘文件保存;(2) 读取磁盘文件并显示输出所有学生的籍贯信息;(3) 按学号或姓名查询其籍贯;(4)

3、按籍贯查询并输出该籍贯的所有学生;(5) 能添加、删除和修改学生的籍贯信息;(6) 显示输出天津籍和非天津籍学生的信息并可分别存盘;2 设计思想该程序运用了结构体数组的输入,输出,修改及存储,采用循环的方式对程序进行编写,同时也采用循环的方式对程序进行输入、显示、查询、检索、删除、编辑等操作。实现编程的意义。3系统完成功能及功能框图每条记录包括一个学生学号、姓名、籍贯。1、输入功能:可以一次完成无数条记录的输入。2、显示功能:完成全部学生记录的显示。3、查找功能:完成按姓名、学号查找学生记录,并显示。4、修改功能:通过查找学生姓名、学号,修改学生记录。5、保存功能:将学生记录保存到任何自定义的

4、文件中。6、读取功能:将保存到文件中的学生记录读取出来。7、分类功能:分别显示天津籍跟非天津籍的学生,并分别存盘,且根据需要显示出来。8、应提供一个界面来调用各个功能,调用界面和功能的操作界面应尽可能清晰美观。功能图显示: 录 入入删 除入编 辑入输 出入 查 询入显示是否为天津籍主要功能 4界面设计4.1主界面:图 14.2 显示已经存入的学生籍贯信息记录图 24.3 删除学生记录界面 图 34.4 修改学生籍贯界面图 434.5 查询显示所有上海籍的学生图 54.6 显示天津籍跟非天津籍的学生图 64.7 此次学生籍贯管理系统公共数据结构如下:#define MAX300 定义常量N表示可

5、录入最大学生数int i,j、k,sum, i表示第几位学生,jk都用来存放赋的值,sum表示查询时该学生不存在的学生数0人int count存放学生总人数int i 变量i存放循环次数struct student 定义一个名为student的结构体,这个结构体定义了学生的基本信息char no 定义学生的学号char name 定义学生的姓名char ad定义学生的籍贯int b 用来跳出某项功能 struct student、struct student stuMAX,定义两个结构体,两者是嵌套的。dd是全局的结构体变量名5 小结通过这次课设,我学会了如何把数据结构的知识应用到实践当中,同

6、时也进一步加深了对c/c+语言语法的应用,以及深刻的掌握了数据结构和c/c+语言的结合运用。 在编程过程中,遇到了许多问题,在一次次的运行错误后,总是发现问题的所在,并且一步步加以改正,也从中学到了许多知识,感觉又重新学习了一次数据结构课程。虽然我的程序还不够完善,还需加以改进以实现更多的功能,但是我会尽我最大的努力去完成它,我相信我会努力去把程序做的更加完美。参考文献1严蔚敏、吴伟民编著. 数据结构(C语言版).清华大学出版社。2藤国文等编著. 数据结构课程设计. 北京:清华大学出版社 。3齐景嘉编著. 数据结构(含实训). 东南大学出版社。4朱儒荣、朱辉等编著. 数据结构常见题型解析与模拟

7、题 西北工业大学出版社。5徐孝凯,贺桂英等编著. 数据结构(C语言描述). 清华大学出版社。6徐孝凯编著.数据结构实用教程. 北京: 清华大学出版社。7严蔚敏,陈文博编著. 数据结构及算法教程. 北京: 清华大学出版社。8刘振安,刘燕君等编著. C 程序设计课程设计. 北京: 机械出版社。9李建学、李光元、吴春芳等编著. 数据结构课程设计案例精编. 清华大学出版社。附录:程序源代码#include #include #include #include #define MAX 300struct student char name10; / 姓名 char no50; / 学号 char ad2

8、0; /籍贯;struct data int count; / 当前学生数组中学生的个数 struct student stuMAX; / 学生数组 dd;/ 显示主菜单void menu() system(cls); printf(n); printf(ttt*n); printf(ttt* *n); printf(ttt* 学生籍贯信息记录簿 *n); printf(ttt* *n); printf(ttt* 0 退出 *n); printf(ttt* 1 查看所有学生信息 *n); printf(ttt* 2 输入学生记录 *n); printf(ttt* 3 删除学生记录 *n); p

9、rintf(ttt* 4 修改学生籍贯 *n); printf(ttt* 5 查询(学号) *n); printf(ttt* 6 查询(姓名) *n); printf(ttt* 7 查询(籍贯) *n);printf(ttt* 8 显示天津籍与非天津籍 *n); printf(ttt* *n);printf(ttt*n); / 等待用户按回车后回到主菜单void to_menu() char c1,c2; printf(nnn按回车键返回主菜单.); scanf(%c%c,&c1,&c2);menu();/ 查看所有学生信息void view_data() int i; printf(姓名t学

10、号tt籍贯);printf(n-n); for(i=0;idd.count;i+) printf(%st%st%sn,,dd.stui.no,dd.stui.ad);/ 将数据从结构体数组保存到文件中void save_data() FILE *fp; int i,k; k=dd.count; fp=fopen(c:/dada.txt,w); fwrite(&k,sizeof(int),1,fp); for(i=0;ik;i+) fwrite(&dd.stui,sizeof(struct student),1,fp);fclose(fp);/ 输入学生记录void ad

11、d_data() struct student st; int b; int k; int i,j; while(1) j=0; printf(n请输入学生信息:); printf(n姓名t学号tt籍贯);printf(n-n); scanf(%s%s%s,,st.no,st.ad); for(i=0;idd.count;i+) if(strcmp(dd.stui.no,st.no)=0) j=1; printf(学号录入重复,请重新输入!); break; if(j=1) continue; if(j=0) k = dd.count; strcpy(,s

12、); strcpy(dd.stuk.no,st.no); strcpy(dd.stuk.ad,st.ad); dd.count+; printf(nn继续添加学生信息1-yes 0-no:); scanf(%d,&b); if(b=0) break; save_data();/ 将数据从文件读到结构体数组中void read_data()FILE *fp;int i,k;struct student st;k=0;if(access(c:/dada.txt,0)=-1)/ 如果文件不存在 fp=fopen(c:/dada.txt,w);fwrite(&k,sizeof(int),1

13、,fp);fclose(fp);fp=fopen(c:/dada.txt,r);fread(&k,sizeof(int),1,fp);dd.count=k;for(i=0;ik;i+) fread(&st,sizeof(struct student),1,fp);strcpy(,);strcpy(dd.stui.no,st.no); strcpy(dd.stui.ad,st.ad);fclose(fp);/ 删除学生记录void delete_data()int i,k;char no50;printf(n请输入要删除学生的学号:);scanf(%s,no

14、);k=-1;for(i=0;idd.count;i+)if(strcmp(dd.stui.no,no)=0) k=i;break;if(k=-1)printf(nn没有找到该学生(学号-%s)!,no); elsefor(i=k;idd.count;i+) strcpy(,dd.stui+1.name); strcpy(dd.stui.no,dd.stui+1.no); strcpy(dd.stui.ad,dd.stui+1.ad); dd.count-;save_data();printf(nn删除(学号-%s)成功!,no);/ 编辑学生记录void edit_d

15、ata()int i,k;char no50,ad20;printf(n请输入要编辑学生的学号:);scanf(%s,no);k=-1;for(i=0;idd.count;i+) if(strcmp(dd.stui.no,no)=0) k=i;break;if(k=-1)printf(nn没有找到该学生(学号-%s)!,no);else printf(n姓名:%s,学号:%s,,dd.stuk.no);printf(n请修改学生数据:); printf(n籍贯:); scanf(%s,ad); strcpy(dd.stuk.ad,ad); / 查询(学号)void qu

16、ery_data_no()int i,k;char no50;printf(n请输入要查询学生的学号:);scanf(%s,no);k=-1;for(i=0;idd.count;i+) if(strcmp(dd.stui.no,no)=0) printf(nn姓名t学号tt籍贯);printf(n-n);k=i;printf(%st%st%sn,,dd.stui.no,dd.stui.ad);if(k=-1) printf(nn没有找到该学生(学号-%s)!,no); / 查询(姓名)void query_data_name()int i,k;char name10;p

17、rintf(n请输入要查询学生的姓名:);scanf(%s,name);k=-1;for(i=0;idd.count;i+)if(strcmp(,name)=0) printf(nn姓名t学号tt籍贯);printf(n-n); k=i;printf(%st%st%sn,,dd.stui.no,dd.stui.ad);if(k=-1) printf(nn没有找到该学生(姓名-%s)!,name); /查询(籍贯)void query_data_address() int i,sum=0;char ad20; printf(请输入籍贯信息:); s

18、canf(%s,ad); printf(该籍贯的学生有:); for(i=0;idd.count;i+) if(strcmp(dd.stui.ad,ad)=0) printf(%st,); sum+; if(sum=0)printf( 0 人 n);/判断显示天津籍void Dis()int i; printf(天津学生:n); printf(学号tt 姓名 籍贯n);for(i=0;idd.count;i+) if(strcmp(dd.stui.ad,天津)=0) printf(%st%7s %5sn,dd.stui.no,,dd.stui.ad); pri

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论