*******************实践教学*******************兰州理工大学计算机与通信学院2011年春季学期C程序设计课程设计题目:学生选课系统专业班级:软件一班姓名:黄锋学号:10240506指导教师:王连相成绩:摘要学生选课系统是C语言应运的一个简单实例,它能实现选课信息的输入、删除、查找、保存等功能。
该系统由七个模块组成,各模块的完成分别由指针、数组、链表等实现,最后通过主函数将各个模块加以联结组成此简单的学生选课管理系统。
该系统有查找方便、可靠性高、存储量大、保密性好等优点,是一个教育单位不可缺少的部分。
关键词:C语言;学生;信息;选课目录一、需求分析 (1)二、总体设计 (2)三、详细设计 (3)1、数据定义 (3)2、算法流程图 (4)四、编码 (7)五、测试 (9)六、设计总结 (9)致谢 (14)参考文献 (15)一、需求分析经过简单的调研分析,可以基本确定学生选课系统主要用来实现对选课信息的输入、删除、保存、查找等功能。
1·录入课程信息教务系统对课程进行安排。
2·课程管理用户可以查看新增课程和已删除课程。
3·录入学生信息学生可以输入自己的基本信息。
4·学生信息管理系统可以对学生输入的信息进行管理,同时用户也可以进行自我信息更改。
5·学生选课学生可以查询已选课程和可选课程,然后进行选课。
6·系统信息查看及及存储用户可以查看课程信息和学生信息以及及存储自己信息。
7·退出系统用户完成在学生成绩管理系统的一系列操作后要离开,则就需退出系统。
二、总体设计课程管理学生选课系统录入课程信息录入学生信息学生选课学生信息管理系统信息查看退出系统三、详细设计1、数据定义struct couse * head1;struct student * head2;struct couse//课程信息结构体{int num1;char name1[20];int score;int nelepeo;//课程已选人数int Melepeo;//课程人数上限struct couse * next;};struct student//学生信息结构体{int num2;char name2[20];int nelenum[50];//已选课程编号int nelen;//已选课程数量struct student * next;}; FILE *fp; //文件指针变量int i,j // 定义变量i,jchar name[4],code[7];//定义数组变量2、算法流程图1)保存函数Save()的算法流程图FILE *fp;(fp=fopen(outfile,"wprintf("can not openprintf("\nSavingp!=NULLfwrite(p,sizeof(SALARfclose(fp);保存函数Save()的算法流程图如图2所示注:out 为输出函数。
图2 查找的算法流程图2)载入函数load 流程图find 函数out 函数输入i 的值sep 函数J=-1输出date is notfind输出姓名,学号,成绩是否图3 load 函数的流程图load 函数用“rb”方式打开“stu_list”文件fread(&stu[i],sizeof(struct student_type))out 函数关闭文件i<SIZE否是四、编码第一步:分析问题根据课题,调研分析此程序要实现那些功能。
并确定程序的总体设计方案。
第二步:画出程序的基本轮廓根据程序的总体设计方案画出程序的流程图,把一个较为复杂的问题拆分,也使程序的功能较为直观的呈现出来。
第二步:实现该程序把整个问题拆分为若干个子模块,然后确定每个模块一个子功能。
五、测试程序的主界面·录入课程界面课程管理界面录入学生信息界面学生信息管理界面学生选课界面系统信息查看及存储界面六、设计总结本期课设终于完成了,也许是第一次做课设,经验不足的缘故吧,总的感觉就是难。
课设前期无从下手,经过知道老师的讲解才对这次课设有了初步的了解。
课设虽然完成,但其中还有许多缺陷,比如源代码编写较短,因而系统功能简单;还有就是虽然有查找功能,但其中有漏洞,不能确定的查找出某个学生的信息,查找只是一个大体的范围。
这些都是本次课设的不足之处。
当然通过这次课设,我收获还是很大的,虽然这次的课设,程序不是完全由我们自己编写的,只是通过把一个相似的例子加以修改得到的。
这些程序看起来比较容易,但要程序实现要求的几个功能却不容易。
而且要看懂每一个函数也不是十分容易的。
当然在修改程序的过程中也收获了许多以前忽略的东西。
在修改的过程中巩固了基础,认识了自己以前常犯的错误,也发现了自己的不足之处。
当然通过这次课程设计,也增加了我学习软件技术的兴趣,虽然还不明确软件技术包含的具体内容,但从C语言这门课程开始,已发现程序设计的乐趣,在学习C语言的过程中也学到了许多计算机应用基础知识。
在具体操作中对这学期所学的C语言的理论知识得到巩固,达到实训的基本目的,也发现自己的不足之出,在以后的上机中应更加注意,同时体会到C语言具有的语句简洁,使用灵活,执行效率高等特点。
发现上机实训的重要作用,特别是对数组和循环有了深刻的理解。
通过实际操作,学会C语言程序编程的基本步骤、基本方法,开发了自己的逻辑思维能力,培养了分析问题、解决问题的能力。
致谢紧张又忙碌的课设学习终于结束了,在本次课设中我们也取得了很大的成就。
在此衷心感谢学院安排这次课设,让我们又多了一次交流学习的机会,更好的巩固了所学知识,拓展了知识面。
本次课设能取得成功,要感谢学院老师的帮助以及张墨逸老师的热心指导。
在课设期间,指导老师帮助我们分析思路,查找错误,修正不足,才使得我们的系统做得更加完善。
其次是要感谢和我同组的同学,感谢他们对我学习的帮助,对我在期间工作的指导与支持。
参考文献1.姜灵芝,余健. C语言课程设计案例精编.北京:清华大学出版社,2008 2.王新,孙雷. C语言课程设计.北京:清华大学出版社,20093.游洪跃、彭骏、谭斌.C语言程序设计实验与课程设计教程.北京:清华大学出版社,20114.王连相.C/C++程序设计上机指导与测试. 北京:中国铁道出版社,2006 5.C语言函数手册,机械工业出版社,1999附录:#include<stdio.h>#include<stdlib.h>int N1,N2,kk1,kk2,kk3;struct couse * head1;struct student * head2;struct couse//课程信息结构体{int num1;char name1[20];int score;int nelepeo;//课程已选人数int Melepeo;//课程人数上限struct couse * next;};struct student//学生信息结构体{int num2;char name2[20];int nelenum[50];//已选课程编号int nelen;//已选课程数量struct student * next;};void Ms(){for(kk1=0;kk1<1100;kk1++)for(kk2=0;kk2<1200;kk2++)for(kk3=0;kk3<1200;kk3++);}void keyboardc()//录入课程子函数(从键盘录入){struct couse *p1,*p2;N1=0;p1=p2=(struct couse*)malloc(sizeof(struct couse));printf("课程编号\t课程名称\t学分\t课程人数上限\n");scanf("%d%s%d%d",&p1->num1,p1->name1,&p1->score,&p1->Melepeo); p1->nelepeo=0;head1=NULL;while(p1->num1!=0){N1=N1+1;if(N1==1)head1=p1;else p2->next=p1;p2=p1;p1=(struct couse * )malloc(sizeof(struct couse));scanf("%d%s%d%d",&p1->num1,p1->name1,&p1->score,&p1->Melepeo);p1->nelepeo=0;}p2->next=NULL;}void filec()//录入键盘子函数(从文件录入){FILE * fp;char filepath[20];struct couse *p1,*p2;N1=0;printf("输入要读入的文件路径:");getchar();gets(filepath);if((fp=fopen(filepath,"r"))==NULL){printf("找不到%s文件!\n",filepath);exit(0);}p1=p2=(struct couse*)malloc(sizeof(struct couse));fscanf(fp,"%d%s%d%d%d",&p1->num1,p1->name1,&p1->score,&p1->nelepeo,&p1->Melepeo); head1=NULL;while(!feof(fp)){N1=N1+1;if(N1==1)head1=p1;else p2->next=p1;p2=p1;p1=(struct couse * )malloc(sizeof(struct couse));fscanf(fp,"%d%s%d%d%d",&p1->num1,p1->name1,&p1->score,&p1->nelepeo,&p1->Melepeo); }p2->next=NULL;}void inputc()//录入课程主函数{int i;printf("\t\t\t录入课程信息\n");printf("\n1.从键盘录入\n");printf("2.从文件录入\n");printf("3.返回主菜单\n");printf("请选择(1~3):\n");scanf("%d",&i);switch(i){case(1):keyboardc();break;case(2):filec();break;case(3):break;}}void insertc(struct couse *incouse)//课程管理子函数(增加课程) {struct couse *p0,*p1,*p2;p1=head1;p0=incouse;if(head1==NULL){head1=p0;p0->next=NULL;}else{while((p0->num1 > p1->num1) && (p1->next!=NULL)){p2=p1;p1=p1->next;}if(p0->num1 <= p1->num1){if(head1==p1) head1=p0;else p2->next=p0;p0->next=p1;}else{p1->next=p0;p0->next=NULL;}}N1=N1+1;}void delc(int num1)//课程管理子函数(删除课程)struct couse *p1,*p2;if(head1==NULL){printf("\n没有课程,无法删除!\n");goto end;}p1=head1;while(num1!=p1->num1 && p1->next!=NULL){p2=p1;p1=p1->next;}if(num1==p1->num1){if(p1==head1) head1=p1->next;else p2->next=p1->next;printf("已删除该编号课程!\n");N1=N1-1;}else printf("无该编号的课程!\n");end:;}void managementc()//课程管理主函数{struct couse * incouse;int i,num1;printf("\t\t\t课程管理\n");printf("1.新增课程\n");printf("2.删除课程\n");printf("3.返回主菜单\n");printf("请选择(1~3):\n");scanf("%d",&i);switch(i){case(1):{incouse=(struct couse *)malloc(sizeof(struct couse));printf("课程编号\t课程名称\t学分\t课程人数上限\n");scanf("%d%s%d%d",&incouse->num1,incouse->name1,&incouse->score,&incouse->Melepeo); incouse->nelepeo=0;break;}case(2):{printf("请输入要删除课程的编号:\n");scanf("%d",&num1);delc(num1);break;}case(3):break;}}void keyboards()//录入学生信息子函数(从键盘录入) {int i;struct student *p1,*p2;N2=0;p1=p2=(struct student *)malloc(sizeof(struct student)); printf("学生学号\t学生姓名\n");scanf("%d%s",&p1->num2,p1->name2);p1->nelen=0;for(i=0;i<20;i++) p1->nelenum[i]=0;head2=NULL;while(p1->num2!=0){N2=N2+1;if(N2==1)head2=p1;else p2->next=p1;p2=p1;p1=(struct student * )malloc(sizeof(struct student)); scanf("%d%s",&p1->num2,p1->name2);p1->nelen=0;for(i=0;i<20;i++) p1->nelenum[i]=0;}p2->next=NULL;}void files()//录入学生信息子函数(从文件录入){int i=0;FILE * fp;char filepath[20];struct student *p1,*p2;printf("输入要读入的文件路径:");getchar();gets(filepath);if((fp=fopen(filepath,"r"))==NULL){printf("找不到%s文件!\n",filepath);exit(0);}p1=p2=(struct student*)malloc(sizeof(struct student));fread(p1,sizeof(struct student),1,fp);head2=NULL;while(!feof(fp)){i=0;N2=N2+1;if(N2==1)head2=p1;else p2->next=p1;p2=p1;p1=(struct student * )malloc(sizeof(struct student));fread(p1,sizeof(struct student),1,fp);}p2->next=NULL;}void inputs()//录入学生信息主函数{int i;printf("\t\t\t录入学生信息\n");printf("\n1.从键盘录入\n");printf("2.从文件录入\n");printf("3.返回主菜单\n");printf("请选择(1~3):\n");scanf("%d",&i);switch(i){case(1):keyboards();break;case(2):files();break;case(3):break;}}void inserts(struct student * incouse)//学生信息管理子函数(填加学生信息) {struct student *p0,*p1,*p2;p0=incouse;if(head2==NULL){head2=p0;p0->next=NULL;}else{while((p0->num2 > p1->num2) && (p1->next!=NULL)) {p2=p1;p1=p1->next;}if(p0->num2 <= p1->num2){if(head2==p1) head2=p0;else p2->next=p0;p0->next=p1;}else{p1->next=p0;p0->next=NULL;}}N2=N2+1;}void dels(int num2)//学生信息管理子函数(删除学生信息) {struct student *p1,*p2;if(head2==NULL){printf("\n没有该学生信息,无法删除!\n");goto end;}p1=head2;while(num2!=p1->num2 && p1->next!=NULL){p2=p1;p1=p1->next;}if(num2==p1->num2)if(p1==head2) head2=p1->next;else p2->next=p1->next;printf("已删除该学生信息!\n");N2=N2-1;}else printf("无该学号的学生!\n");end:;}void managements()//学生信息管理主函数{struct student * incouse;int i,num2;printf("\t\t\t学生信息管理\n");printf("1.新增学生信息\n");printf("2.删除学生信息\n");printf("3.返回主菜单\n");printf("请选择(1~3):\n");scanf("%d",&i);switch(i){case(1):{incouse=(struct student *)malloc(sizeof(struct student)); incouse->nelen=0;incouse->nelenum[0]=0;printf("学生学号\t学生姓名\n");scanf("%d%s",&incouse->num2,incouse->name2); inserts(incouse);break;}case(2):{printf("请输入要删除学生的学号:\n");scanf("%d",&num2);dels(num2);break;}case(3):break;}}void elect(struct student * s)//选课struct couse * p;int num1,i;printf("请输入要选课的编号:\n");scanf("%d",&num1);for(i=0;s->nelenum[i]!=0;i++);s->nelenum[i]=num1;(s->nelen)++;p=head1;while(p->num1!=num1) p=p->next;(p->nelepeo)++;}void cheak()//学生选课子函数(查询可选课程){char e;struct couse * c;struct student * s;int num2,i,j=0,t=0;printf("请输入你的学号:");scanf("%d",&num2);s=head2;while(s->num2!=num2 && s->next!=NULL) s=s->next;if(s->num2!=num2){printf("不存在你的信息,请进入主菜单录入你的信息!\n"); goto end;}c=head1;printf("你的可选课程编号:\n");while(c!=NULL){for(t=0,i=0;s->nelenum[i]!=0;i++){if(c->num1==s->nelenum[i]) t=1;}if(t==0 && (c->nelepeo!=c->Melepeo)){printf("%d\n",c->num1);j++;}c=c->next;}if(j==0)printf("你已选完所有课程,无法再多选!\n");goto end;}printf("选课(y/n)?:\n");getchar();e=getchar();i=0;while(e=='y'){elect(s);printf("继续选课(y/n)?:\n");getchar();e=getchar();}end:;}void back(struct student * p)//退课{struct couse * p1;int num1,i,j;printf("请输入你要退掉的课程编号:\n");scanf("%d",&num1);p1=head1;while(p1->num1!=num1) p1=p1->next;for(i=0;p->nelenum[i]!=num1;i++);for(j=i;p->nelenum[j]!=0;j++) p->nelenum[j]=p->nelenum[j+1]; p->nelenum[--j]=0;(p1->nelepeo)--;printf("退课成功!\n");}void hcheak()//学生选课子函数(查询已选课程){char c;struct couse * p0;struct student * p;int num2,i,f=0;printf("请输入学号:\n");scanf("%d",&num2);p=head2;while(p->num2!=num2 && p!=NULL) p=p->next;if(p==NULL){printf("不存在你的信息,请回主菜单录入信息:\n"); goto end;}printf("已选课程编号:\n");if(p->nelenum[0]==0){printf("你还没选课!\n");goto end;}for(i=0;p->nelenum[i]!=0;i++){printf("%d\n",p->nelenum[i]);p0=head1;while(p0->num1!=p->nelenum[i]) p0=p0->next;f=f+p0->score;}printf("总学分:%d\n",f);printf("是否进行退课(y/n)?");getchar();c=getchar();while(c=='y'){back(p);printf("继续退课(y/n)?");getchar();c=getchar();(p->nelen)--;}end:;}void elective()//学生选课主函数{int i;printf("\t\t\t学生选课\n");printf("1.查询可选课程\n");printf("2.查询已选课程\n");printf("3.返回主菜单\n");printf("请输入(1~3):\n");scanf("%d",&i);switch(i)case(1):cheak();break;case(2):hcheak();break;case(3):break;}}void listc()//输出课程信息{struct couse * p;p=head1;printf("课程编号课程名称学分课程已选人数课程人数上限\n");while(p!=NULL){printf("%-8d%10s%6d%8d%12d\n",p->num1,p->name1,p->score,p->nelepeo,p->Melepeo); p=p->next;}}void lists()//输出学生信息{struct student * p;p=head2;printf("学生学号学生姓名已选课程数量\n");while(p!=NULL){printf("%-4d %10s %6d\n",p->num2,p->name2,p->nelen);p=p->next;}}void intoc()//存储课程信息{FILE * fp;struct couse * p;char filepath[30];printf("输入课程信息要保存的文件路径:");getchar();gets(filepath);if((fp=fopen(filepath,"w"))==NULL){printf("\n保存失败!");exit(0);}p=head1;while(p!=NULL)fprintf(fp,"%d %s %d %d %d\n",p->num1,p->name1,p->score,p->nelepeo,p->Melepeo); p=p->next;}fclose(fp);printf("课程信息已保存在%s中!\n",filepath);}void intos()//存储学生信息{FILE * fp;struct student * p;char filepath[30];printf("输入学生信息要保存的文件路径:");getchar();gets(filepath);if((fp=fopen(filepath,"w"))==NULL){printf("\n保存失败!");exit(0);}p=head2;while(p!=NULL){fwrite(p,sizeof(struct student),1,fp);p=p->next;}fclose(fp);printf("学生信息已保存在%s中!\n",filepath);}void into()//存储信息{int i;printf("1.存储课程信息\n");printf("2.存储学生信息\n");printf("3.返回主菜单\n");printf("请输入(1~3)\n");scanf("%d",&i);switch(i){case(1):intoc();break;case(2):intos();break;case(3):break;}}void store()//信息主函数{int i;printf("\t\t系统信息查看及存储\n"); printf("1.查看课程信息\n");printf("2.查看学生信息\n");printf("3.存储信息\n");printf("4.返回主菜单\n");printf("请输入(1~4):\n");scanf("%d",&i);switch(i){case(1):listc();break;case(2):lists();break;case(3):into();break;case(4):break;}}int main()//主函数{int i;start:printf("\n\t\t\t欢迎使用学生选课系统!\n"); printf("菜单:\n");printf("1.录入课程信息\n");printf("2.课程管理\n");printf("3.录入学生信息\n");printf("4.学生信息管理\n");printf("5.学生选课\n");printf("6.系统信息查看及存储\n");printf("7.退出系统\n");printf("\n请输入菜单选项(1~7):\n"); scanf("%d",&i);if(i<1 || i>7){printf("输入错误,请重输:\n");goto start;}switch(i){case(1):{system("cls");inputc();goto start; break;}case(2):{system("cls"); managementc(); goto start; break;}case(3):{system("cls"); inputs();goto start; break;}case(4):{system("cls"); managements(); goto start; break;}case(5):{system("cls"); elective();goto start; break;}case(6):{system("cls"); store();goto start; break;}case(7):{system("cls");printf("感谢使用本系统!\n\n再见!\n"); }}return(0);}。