学籍管理系统.docx

上传人:小飞机 文档编号:3426101 上传时间:2023-03-13 格式:DOCX 页数:23 大小:42.81KB
返回 下载 相关 举报
学籍管理系统.docx_第1页
第1页 / 共23页
学籍管理系统.docx_第2页
第2页 / 共23页
学籍管理系统.docx_第3页
第3页 / 共23页
学籍管理系统.docx_第4页
第4页 / 共23页
学籍管理系统.docx_第5页
第5页 / 共23页
亲,该文档总共23页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《学籍管理系统.docx》由会员分享,可在线阅读,更多相关《学籍管理系统.docx(23页珍藏版)》请在三一办公上搜索。

1、学籍管理系统 实验题目:学籍管理系统 一、实验目的 综合应用所学的C语言程序设计知识,自行设计并实现一个较为完整的小型管理信息系统。通过系统分析、系统设计、编程实现,写实验报告等环节,初步掌握软件系统的设计方法和步骤,提高灵活运用程序语言进行软件开发的技能,提高程序设计水平和分析问题、解决问题的能力。 二、实验内容 1):熟悉C语言的开发环境,按照给定的上机步骤练习完成; 2):熟悉C程序的编辑,编译,链接和运行的过程。 3):编译一个应用系统程序,形成一个软件系统。 三、详细设计及运行结果 1、算法设计 学籍管理系统程序采用了结构化程序设计的思想,将程序分解成许多模块,再由主函数调用这些模块

2、,实现不同的功能。 1、学生信息结构体:储存学生信息。 2、主菜单模块:通过利用输出函数显示输出主菜单信息。 3、提示错误信息模块:通过利用输出函数输出提示错误信息。 4、提示没有找到模块:通过利用输出函数输出提示没有找到该学生。 5、输出中文、英文模块:通过利用输出函数输出中文提示及学生数据。 6、定位模块:定位连表中符要求合的接点,并返回该指针。 7、增加学生信息模块:通过指针的不断后移逐个接受学生信息并将学生信息付给相应变量。 8、查询学生信息模块:根据用户选择按学号或按姓名查询,分别按学号或姓名逐个比较输入的数据与结构体中的数据,有匹配的则输出,没有则提示没有找到。 9、删除信息模块:

3、根据用户选择按学号或按姓名删除,分别比对输入数据和结构体中的数据,有匹配的则删除,没有则提示无信息可删。 10、修改信息模块:通过用户输入的学号找到相应学生,然后逐项修改学生信息,否则提示无此学生。 11、显示信息模块:将学生信息输出。 12、保存信息模块:将接受的结构体信息利用指针存入文件中。 13、排序模块:按照学生的最高分进行排序,输出。 14、统计学生信息模块:逐项比较相邻两项的成绩信息,得到每项最大值,并输出统计结果。 15、主函数:通过调用各模块来实现学生信息的管理。 2、模块图设计 总分主函数 增删查修加除询改学学学学生生生生信信信信息 息 息 息 按按按按学姓学姓号名号名删删查

4、查除 除 询 询 3、流程图设计 显保学统示存生计 学学总最 生生分高信信排分 息 息 序 总分 按按按按按数英C总平学语语分均成成言排分绩绩成序 排排排绩序 序 序 排序 1、主函数 能 文件是否能打开 不能 提示文件已打开,正在导入 提示文件不能打开 将文件内容放入节点中 关闭文件 输出菜单,请用户选择 Choice 01 增加学生信息 2 删除学生信息 3 查询学生信息 4 修改学生信息 5 保存学生信息 6 统计最高分 7 按总分排名 按最高分打印 8 返回 2、增加学生信息模块: N 是否存在 Y 输入信息 提示学生已存在 给相应变量 返回 3删除学生信息 否 文件是否为空 是 输出

5、提示:1、按学号2、按姓名 1 choice 提示输入学号 提示输入姓名 2 没有资料 接收输入学号 接收输入姓名 是否找到 否是 删除该生信息 提示没有找到 返回 4.查询学生信息 否 文件是否为空 是 输出提示:1、按学号2、按姓名 1 choice 提示输入学号 提示输入姓名 2 提示无资料可查 接收输入学号 接收输入姓名 是否找到 否提示没有找到 是 输出查询结果 返回 4、修改学生信息 是 文件中是否有资料 否 提示输入要修改的学号 提示无资料可修改 接收输入的学号 是否找到 否 提示没有找到 是 写入新数据并给相应变量 提示资料已修改完毕 返回 6、显示学生信息 是 文件是否能打开

6、 否 依次显示学生信息 提示无资料可查 返回 7、保存学生信息 是 文件是否能打开 否 将输入内容存入文件 提示文件打开错误 提示保存完成 返回 8.按总分排序 是 资料知否存在 否 依次比较总分得出最大值 提示无资料查 输出比较结果 返回 9、统计学生最高分 是 资料知否存在 否 依次比较总分得出最大值 提示无资料可统计 依次比较平均分得出最大值 依次比较数学成绩得出最大值 依次比较英语成绩得出最大值 依次比较C语言成绩得出最大值 输出比较结果 返回 四、调试情况,设计技巧及体会 1、本系统在VC6下编译调试通过,可顺利运行,各项功能达到设计要求 本系统采用分模块调试的方法进行编译,即完成一

7、个函数功能模块就编译一个功能模块,最后再进行整体编译并生成可执行文件honest.exe。 在调试过程中主要碰到以下问题: 输入函数中的取地址符即“&”不能正确使用,导致程序在输入数据时发生错误。 在比较两个字符串时不能正确使用“strcmp”函数,导致比较结果不能输出。 在应用指针时没有注意头结点中的数据域中是不存放数据,导致指针指向错误。 2、在这次课程设计中我充分体会到C语言作为一门编程的基本语言它的精妙。通过这次课程设计使我了解到我有很多的不足,在程序调试的时候常常会因为几个错误而弄得心烦,这说明我对知识的掌握还不够牢,在程序设计的过程中也暴露出了我的诸多弊端,借这次课程设计的机会我会

8、认真的加以改正,多多看书 多去图书馆学习,同时应该增强自己的实践能力,为以后的学习打下坚实的基础。 五、源程序清单(略,详见电子版实验报告) #include stdio.h #include conio.h #include stdlib.h /*包含后面使用的exit等函数*/ #include string.h/*包含号面使用的strcmp等函数*/ int havesave=0; /*全集变量*/ struct student char num10;/* 学号 */ char name18; char sex3; int clanguage; int math; int english

9、; int totle; int average; ; typedef struct node /*使用typedef语句,简化程序后续声明定义的键盘输入*/ struct student data; struct node *next; Node,*Link; void menu printf(n); printf( n); printf( n); printf( n); printf( n); printf( t1添加学生资料ttttt2删除学生资料 n); printf( n); printf( t3查询学生资料ttttt4修改学生资料 n); printf( n); printf( t

10、5保存学生资料ttttt6统计最高分 n); printf( n); printf( t7按总分排名ttttt8打印学生成绩 n); printf( n); printf( t9帮助信息ttttt0退出系统 n); printf( n); printf( n); printf( n); printf( n); printf(n); printf(n); void print_san printf(-n); void Wrong printf(n=提示:输入错误!n); void Nofind printf(n=提示:没有找到该学生!n); void printchinese /* 本函数用于输

11、出中文 */ printf(t 学号t 姓名 性别 英语成绩 数学成绩 C语言成绩 总分 平均分n); void printenglish(Node *p)/* 本函数用于输出英文 */ printf(t%-9s%st%st%dt%dt%dt %dt %dn,p-data.num,p-data.name,p-data.sex,p-data.english,p-data.math,p-data.clanguage,p-data.totle,p-data.average); void printhelp printf(该程序为用C语言编写的学生管理程序,第一次进入该程序需要创建学生数据n); pr

12、intf(以后进入可根据菜单栏显示实现各项功能,系统默认保存文件位置为D:/学生管理n); printf(按任意键返回); printf(n); getch; Node* Locate(Link l,char findmess,char nameornum) /* 该函数用于定位链表中符合要求的结点,并返回该指针 */ Node *r; if(strcmp(nameornum,num)=0) /* 按学号查询 */ r=l-next; while(r!=NULL) if(strcmp(r-data.num,findmess)=0) return r; r=r-next; else if(str

13、cmp(nameornum,name)=0) /* 按姓名查询 */ r=l-next; while(r!=NULL) if(strcmp(r-data.name,findmess)=0) return r; r=r-next; return 0; void Add(Link l) /* 增加学生 */ Node *p,*r,*s; char num10; r=l; s=l-next; while(r-next!=NULL) r=r-next; /* 将指针置于最末尾 */ while(1) printf(请你输入学号(以0返回上一级菜单:); scanf(%s,num); if(strcmp

14、(num,0)=0) break; while(s) if(strcmp(s-data.num,num)=0) printf(=提示:学号为%s的学生已经存在,若要修改请你选择4 修改!n,num); print_san; printchinese; printenglish(s); print_san; printf(n); return; s=s-next; p=(Node *)malloc(sizeof(Node); strcpy(p-data.num,num); printf(请你输入姓名:); scanf(%s,p-data.name); getchar; printf(请你输入性别

15、:); scanf(%s,p-data.sex); getchar; printf(请你输入c语言成绩:); scanf(%d,&p-data.clanguage); getchar; printf(请你输入数学成绩:); scanf(%d,&p-data.math); getchar; printf(请你输入英语成绩:); scanf(%d,&p-data.english); getchar; p-data.totle=p-data.english+p-data.clanguage+p-data.math; p-data.average=p-data.totle / 3; /* 信息输入已经

16、完成 */ p-next=NULL; r-next=p; r=p; havesave=1; void Seek(Link l) /* 查询学生 */ int sel; char findmess20; Node *p; if(!l-next) printf(n=提示:没有资料可以查询!n); return; printf(n=1按学号查找n=2按姓名查找n); scanf(%d,&sel); if(sel=1)/* 学号 */ printf(请你输入要查找的学号:); scanf(%s,findmess); p=Locate(l,findmess,num); if(p) printf(tttt

17、查找结果n); print_san; printf(n); printchinese; printenglish(p); printf(n); print_san; printf(按任意键返回); getch; else Nofind; else if(sel=2) /* 姓名 */ printf(请您输入要查找的姓名:); scanf(%s,findmess); p=Locate(l,findmess,name); if(p) printf(tttt查找结果n); print_san; printf(n); printchinese; printenglish(p); printf(n);

18、print_san; printf(按任意键返回); getch; else Nofind; else Wrong; void Del(Link l) /* 删除 */ int sel; Node *p,*r; char findmess20; if(!l-next) printf(n=提示:没有资料可以删除!n); return; printf(n=1按学号删除n=2按姓名删除n); scanf(%d,&sel); if(sel=1) printf(请您输入要删除的学号:); scanf(%s,findmess); p=Locate(l,findmess,num); if(p) r=l; w

19、hile(r-next!=p) r=r-next; r-next=p-next; free(p); printf(n=提示:该学生已经成功删除!n); havesave=1; else Nofind; else if(sel=2) printf(请你输入要删除的姓名:); scanf(%s,findmess); p=Locate(l,findmess,name); if(p) r=l; while(r-next!=p) r=r-next; r-next=p-next; free(p); printf(n=提示:该学生已经成功删除!n); havesave=1; else Nofind; els

20、e Wrong; void Modify(Link l) Node *p; char findmess20; if(!l-next) printf(n=提示:没有资料可以修改!n); return; printf(请您输入要修改的学生学号:); scanf(%s,findmess); p=Locate(l,findmess,num); if(p) printf(请你输入新学号(原来是%s):,p-data.num); scanf(%s,p-data.num); printf(请你输入新姓名(原来是%s):,p-data.name); scanf(%s,p-data.name); getchar

21、; printf(请你输入新性别(原来是%s):,p-data.sex); scanf(%s,p-data.sex); printf(请你输入新的c语言成绩(原来是%d分):,p-data.clanguage); scanf(%d,&p-data.clanguage); getchar; printf(请你输入新的数学成绩(原来是%d分):,p-data.math); getchar; scanf(%d,&p-data.math); printf(请你输入新的英语成绩(原来是%d分):,p-data.english); scanf(%d,&p-data.english); p-data.tot

22、le=p-data.english+p-data.clanguage+p-data.math; p-data.average=p-data.totle/3; printf(n=提示:资料修改成功!n); havesave=1; else Nofind; void Scoreone(Link l) Node *pm,*pe,*pc,*pt,*pa; /* 用于指向分数最高的接点 */ Node *r=l-next; if(!r) printf(n=提示:没有资料可以统计!n); return ; pm=pe=pc=pt=pa=r; while(r!=NULL) if(r-data.clangua

23、ge=pc-data.clanguage) pc=r; if(r-data.math=pm-data.math) pm=r; if(r-data.english=pe-data.english) pe=r; if(r-data.totle=pt-data.totle) pt=r; if(r-data.average=pa-data.average) pa=r; r=r-next; printf(-统计结果-n); printf(总分最高者:t%st%st %dn,pt-data.num,pt-data.name,pt-data.totle); printf(平均分最高者:t%st%st %d分

24、分n,pa-data.num,pa-data.name,pa-data.average); printf(英语最高者:t%st%st n,pe-data.num,pe-data.name,pe-data.english); printf(数学最高者:t%st%st n,pm-data.num,pm-data.name,pm-data.math); printf(c语言最高者:t%st%st n,pc-data.num,pc-data.name,pc-data.clanguage); print_san; printf(按任意键返回n); getch; void Scoretow(Link l)

25、 Link ll; Node *p,*rr,*s; ll=(Link)malloc(sizeof(Node); /* 用于做新的连表 */ ll-next=NULL; if(l-next=NULL) printf(n=提示:没有资料可以排序!n); return ; p=l-next; while(p) s=(Node*)malloc(sizeof(Node); /* 新建接点用于保存信息 */ s-data=p-data; s-next=NULL; rr=ll; while(rr-next!=NULL & rr-next-data.totle=p-data.totle) rr=rr-next

26、; if(rr-next=NULL) rr-next=s; else s-next=rr-next; rr-next=s; p=p-next; free(l); l-next=ll-next; printf(n=提示:排序已经完成!n); %d%d%d分分分void printscore(Link l)/打印成绩信息 Node *p; p=l; if(l!=NULL) printf(n全部成绩为:nn); printf(学号t姓名t数学t英语tC语言t平均分t总分nn); p=p-next; do printf(%st%st%dt%dt%dt%dt%dn, p-data.num, p-data

27、.name,p-data.math,p-data.english,p-data.clanguage,p-data.average,p-data.totle); p=p-next; while(p!=NULL); printf(n); printf(按任意键返回); printf(n); getch; else printf(n目前数据为空,还没有任何信息,请先创建成绩信息!nn); void Save(Link l) FILE* fp; Node *p; int flag=1,count=0; fp=fopen(D:学生管理,wb); if(fp=NULL) printf(n=提示:重新打开文

28、件时发生错误!n); exit(1); p=l-next; while(p) if(fwrite(p,sizeof(Node),1,fp)=1) p=p-next; count+; else flag=0; break; if(flag) printf(n=提示:文件保存成功.(有%d条记录已经保存.)n,count); havesave=0; fclose(fp); void main Link l;/* 连表 */ FILE *fp; /* 文件指针 */ int sel; char c; char chji; int count=0; Node *p,*r; printf(tttt学生成

29、绩管理系统ntttt-西安邮电学院 微电子0901 李欢(17号)n); l=(Node*)malloc(sizeof(Node); l-next=NULL; r=l; fp=fopen(D:学生管理,rb); if(fp=NULL) printf(n=提示:文件还不存在,是否创建?(y/n)n); scanf(%c,&chji); if(chji=y|chji=Y) fp=fopen(D:学生管理,wb); printf(n=提示:文件已经打开,正在导入记录.n); fclose(fp); /* 关闭文件 */ printf(n=提示:记录导入完毕,共导入%d条记录.n,count); el

30、se exit(0); else while(!feof(fp) p=(Node*)malloc(sizeof(Node); if(fread(p,sizeof(Node),1,fp) /* 将文件的内容放入接点中 */ p-next=NULL; r-next=p; r=p; /* 将该接点挂入连中 */ count+; fclose(fp); /* 关闭文件 */ printf(n=提示:记录导入完毕,共导入%d条记录.n,count); while(1) menu; printf(请你选择操作:); scanf(%d,&sel); if(sel=0) if(havesave=1) getc

31、har; printf(n=提示:资料已经改动,是否将改动保存到文件中(y/n)?n); scanf(%c,&c); if(c=y|c=Y) Save(l); printf(n=提示:您已经退出系统,再见!n); break; switch(sel) case 1:Add(l);break; /* 增加学生 */ case 2:Del(l);break;/* 删除学生 */ case 3:Seek(l);break;/* 查询学生 */ case 4:Modify(l);break;/* 修改学生 */ case 5:Save(l);break;/* 保存学生 */ case 6:Scoreone(l);break;/*统计最高分*/ case 7:Scoretow(l);/*按总分排名*/ case 8:printscore(l);break;/*按总分排名打印*/ case 9:printf(ttt=帮助信息=n);printhelp;break; default: Wrong;getchar;break;

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号