ImageVerifierCode 换一换
格式:DOCX , 页数:33 ,大小:282.08KB ,
资源ID:25447781      下载积分:2 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/25447781.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(学籍管理系统C语言课程设计华丽版+详细注释.docx)为本站会员(b****9)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

学籍管理系统C语言课程设计华丽版+详细注释.docx

1、学籍管理系统C语言课程设计华丽版+详细注释 实验题目:学籍管理系统一、实验目的 综合应用所学的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、模块图设计总分3、流程图设计1、主函数2、增加学生信息模块:3删除学生信息4.查询学生信息4、修改学生信息6、显示学生信息7

4、、保存学生信息8.按总分排序9、统计学生最高分 四、调试情况,设计技巧及体会1、本系统在VC6下编译调试通过,可顺利运行,各项功能达到设计要求 本系统采用分模块调试的方法进行编译,即完成一个函数功能模块就编译一个功能模块,最后再进行整体编译并生成可执行文件honest.exe。 在调试过程中主要碰到以下问题:(1)输入函数中的取地址符即“&”不能正确使用,导致程序在输入数据时发生错误。(2)在比较两个字符串时不能正确使用“strcmp”函数,导致比较结果不能输出。(3)在应用指针时没有注意头结点中的数据域中是不存放数据,导致指针指向错误。 2、在这次课程设计中我充分体会到C语言作为一门编程的基

5、本语言它的精妙。通过这次课程设计使我了解到我有很多的不足,在程序调试的时候常常会因为几个错误而弄得心烦,这说明我对知识的掌握还不够牢,在程序设计的过程中也暴露出了我的诸多弊端,借这次课程设计的机会我会认真的加以改正,多多看书 多去图书馆学习,同时应该增强自己的实践能力,为以后的学习打下坚实的基础。五、源程序清单(略,详见电子版实验报告)#include stdio.h #include conio.h#include stdlib.h /*包含后面使用的exit等函数*/#include string.h/*包含号面使用的strcmp等函数*/ int havesave=0; /*全集变量*/

6、 struct student char num10;/* 学号 */ char name18; char sex3; int clanguage; int math; int english; 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); print

7、f( t1添加学生资料ttttt2删除学生资料 n); printf( n); printf( t3查询学生资料ttttt4修改学生资料 n); printf( n); printf( t5保存学生资料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

8、 Wrong() printf(n=提示:输入错误!n); void Nofind() printf(n=提示:没有找到该学生!n); void printchinese() /* 本函数用于输出中文 */ 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.clang

9、uage,p-data.totle,p-data.average); void printhelp() printf(该程序为用C语言编写的学生管理程序,第一次进入该程序需要创建学生数据n); printf(以后进入可根据菜单栏显示实现各项功能,系统默认保存文件位置为D:/学生管理n); printf(按任意键返回); printf(n); getch();Node* Locate(Link l,char findmess,char nameornum) /* 该函数用于定位链表中符合要求的结点,并返回该指针 */ Node *r; if(strcmp(nameornum,num)=0) /*

10、 按学号查询 */ r=l-next; while(r!=NULL) if(strcmp(r-data.num,findmess)=0) return r; r=r-next; else if(strcmp(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

11、(r-next!=NULL) r=r-next; /* 将指针置于最末尾 */ while(1) printf(请你输入学号(以0返回上一级菜单:); scanf(%s,num); if(strcmp(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 *)m

12、alloc(sizeof(Node); strcpy(p-data.num,num); printf(请你输入姓名:); scanf(%s,p-data.name); getchar(); printf(请你输入性别:); 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.engli

13、sh); getchar(); p-data.totle=p-data.english+p-data.clanguage+p-data.math; p-data.average=p-data.totle / 3; /* 信息输入已经完成 */ 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); sc

14、anf(%d,&sel); if(sel=1)/* 学号 */ printf(请你输入要查找的学号:); scanf(%s,findmess); p=Locate(l,findmess,num); if(p) printf(tttt查找结果n); print_san();printf(n); printchinese(); printenglish(p);printf(n); print_san();printf(按任意键返回);getch(); else Nofind(); else if(sel=2) /* 姓名 */ printf(请您输入要查找的姓名:); scanf(%s,findm

15、ess); p=Locate(l,findmess,name); if(p) printf(tttt查找结果n); print_san();printf(n); printchinese(); printenglish(p);printf(n); 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; p

16、rintf(n=1按学号删除n=2按姓名删除n); scanf(%d,&sel); if(sel=1) printf(请您输入要删除的学号:); scanf(%s,findmess); p=Locate(l,findmess,num); if(p) r=l; while(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

17、,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(); else Wrong(); void Modify(Link l) Node *p; char findmess20; if(!l-next) printf(n=提示:没有资料可以修改!n); return; printf(请您输入要修改的学生学号:); scanf(%s,findmess); p=Locate(l,findmess,

18、num); if(p) printf(请你输入新学号(原来是%s):,p-data.num); scanf(%s,p-data.num); printf(请你输入新姓名(原来是%s):,p-data.name); scanf(%s,p-data.name); getchar(); printf(请你输入新性别(原来是%s):,p-data.sex); scanf(%s,p-data.sex); printf(请你输入新的c语言成绩(原来是%d分):,p-data.clanguage); scanf(%d,&p-data.clanguage); getchar(); printf(请你输入新的数

19、学成绩(原来是%d分):,p-data.math); getchar(); scanf(%d,&p-data.math); printf(请你输入新的英语成绩(原来是%d分):,p-data.english); scanf(%d,&p-data.english); p-data.totle=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 *

20、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.clanguage=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.aver

21、age=pa-data.average) pa=r; r=r-next; printf(-统计结果-n); printf(总分最高者:t%st%st %d分n,pt-data.num,pt-data.name,pt-data.totle); printf(平均分最高者:t%st%st %d分n,pa-data.num,pa-data.name,pa-data.average); printf(英语最高者:t%st%st %d分n,pe-data.num,pe-data.name,pe-data.english); printf(数学最高者:t%st%st %d分n,pm-data.num,pm

22、-data.name,pm-data.math); printf(c语言最高者:t%st%st %d分n,pc-data.num,pc-data.name,pc-data.clanguage); print_san(); printf(按任意键返回n);getch(); void Scoretow(Link l) 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;

23、 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; 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); void printscore(Link l)/

24、打印成绩信息 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.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();

25、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=提示:重新打开文件时发生错误!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学生成绩管理系统ntttt-西安邮电学院 微电子0901 李欢(17号)n); l=(Node*)malloc(sizeof(Node); l-next=NULL;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1