收藏 分销(赏)

C语言专业课程设计学生选课系统.docx

上传人:a199****6536 文档编号:2864402 上传时间:2024-06-07 格式:DOCX 页数:38 大小:227.63KB
下载 相关 举报
C语言专业课程设计学生选课系统.docx_第1页
第1页 / 共38页
C语言专业课程设计学生选课系统.docx_第2页
第2页 / 共38页
C语言专业课程设计学生选课系统.docx_第3页
第3页 / 共38页
C语言专业课程设计学生选课系统.docx_第4页
第4页 / 共38页
C语言专业课程设计学生选课系统.docx_第5页
第5页 / 共38页
点击查看更多>>
资源描述

1、武汉理工大学华夏学院课程设计汇报书课程名称: C课程设计 题 目: 学生选课系统程序设计 系 名: 信息工程系 专业班级: 姓 名: 学 号: 指导老师: 成 绩: 3 月 4 日课程设计任务书学生姓名: 专业班级: 指导老师: 工作单位: 设计题目:学生选课系统程序设计初始条件:学生选课系统能提供学生选课,和学生和课程信息管理等一系列功效。要求完成关键任务:(包含课程设计工作量及其技术要求,和说明书撰写等具体要求)1、任务描述假定有n门课程,每门课程有课程编号,课程名称,课程性质,课时,讲课课时,试验或上机课时,学分,开课学期等信息,学生可按要求(如总学分不得少于15)自由选课。试设计一个选

2、修课程系统,使之能提供以下功效:(1)系统以菜单方法工作(2)课程信息和学生选课信息录入功效(课程信息用文件保留)(3)课程信息浏览功效(4)查询功效(5)按学分查询(6)某门课程学生选修情况(可选项)2、本课程包含知识点变量定义、输入和输出函数、结构体类型定义、结构体数组、循环语句、选择语句,文件操作等。设计汇报撰写格式要求:一、课程设计说明书(或汇报书)正文内容【设计题目】比如:学生选课系统【开发环境】硬件环境:微机系列,内存在1G以上,软件环境:Microsoft Windows XP【开发工具】 Microsoft Visual C+ 6.0【完成时间】 -2 -29-.3.4【需求分

3、析】分析叙述用户需要和要实现程序应含有什么样功效。【系统总体设计】在明确了所要处理问题后,很自然地就要提出自己处理问题思绪和方案。让读者了解方案总体设计和关键技术。 要叙述自己设计方案,说明为何要选择或设计这么方案。 具体包含:系统总设计思绪,功效模块图; 使用设计软硬件环境和开发技术和平台等。【系统具体设计】在这部分中,应该含有相关关键实现技术(如使用什么库函数,使用什么循环结构等)。【系统调试和测试】调试:介绍设计过程中碰到问题和处理方法。测试:介绍怎样测试系统,测试中发觉问题和处理方案。【结束语】这部分篇幅不大,对整个设计中做工作、取得结果、心得体会等做一个简单小结。【参考文件】罗列在设

4、计过程中查阅文件名称 注意:参考文件罗列格式为 资料编号作者姓名文件或期刊名称出版社名称,文件出版时间或期刊期号比如:文件 1 谭浩强.,C程序设计(第二版)M,北京:清华大学出版社, 期刊 2 于振海.office XP网上数据存取.计算机应用文摘J,24;69(页)二、课程设计说明书(或汇报书)正文书写格式介绍一、 正文标题层次 正文题序层次是文章结构框架,通常采取社会通用论文书写形式。即章条序码统一用阿拉伯数字表示,题序层次能够分为若干级,各级号码之间加小圆点,末尾一级后面不加小圆点,层次分级通常不超出四级为宜,示例以下:第一级(章) 1 2 3 第二级(条)1.1 1.22.12.2

5、3.1 3.2 第三级(条)1.1.11.1.2 1.2.11.2.22.1.12.1.2 2.2.12.2.23.1.13.1.2 3.2.13.2.2 二、表格 每个表格应有自己表序和表题,表序和表题间空一格。比如:表1.1 XXXX ,且表题和表序应写在表格上方正中处。三、插图 插图图面要整齐、美观,插图应和正文呼应,不能脱节。每幅插图应有图序和图题,图序编号要连续,图序和图题间空一格且要放在插图下方居中处。四、公式 公式应另起一行写在稿纸中央时间安排:周次星期一星期二星期三星期四星期五第2周第1-4节第3-4节第1-4节第1-2节第1-4节地点现教221现教221现教221现教221现

6、教221课程设计考评及评分标准1. 系统完成任务:50分2. 多种技术综合应用:10分3、回复提问情况:20分4. 设计汇报:20分目 录1设计题目12开发环境12.1硬件环境12.2软件环境13 开发工具14完成时间15需求分析16系统总体设计27系统详细设计27.1系统主菜单27.1.1系统主菜单界面27.1.2系统功能模块图37.1.3系统主菜单流程图47.1.4系统主菜单代码47.2录入课程信息67.2.1录入课程信息界面67.2.2录入课程信息模块图67.2.3录入课程信息流程图77.2.4录入课程信息代码77.3课程管理87.3.1课程管理界面87.3.2课程管理模块图97.3.3

7、课程管理流程图97.3.4课程管理代码107.4学生信息管理127.4.1学生信息管理界面127.4.2学生信息管理界面模块图127.4.3学生信息管理流程图127.4.4学生信息管理代码137.5学生选课157.5.1学生选课界面157.5.2学生选课模块图167.5.3学生选课流程图177.5.4学生选课代码188系统调试和测试228.1调试228.2测试259结束语2510参考文献251设计题目学生选课系统2开发环境2.1硬件环境微机系列,内存在1G以上2.2软件环境Win7系统3 开发工具Microsoft Visual C+ 6.04完成时间2月29日3月4日5需求分析用户需求以下:

8、假定有n门课程,每门课程有课程编号,课程名称,课程性质,课时,讲课课时,试验或上机课时,学分,开课学期等信息,学生可按要求(如总学分不得少于15)自由选课。试设计一个选修课程系统。故此,经过分析后我认为程序应该含有以下功效:(1)系统以菜单方法工作(2)课程信息和学生选课信息录入功效(3)课程信息浏览功效(4)查询功效(5)按学分查询6系统总体设计系统由哪多个功效模块组成,给出功效模块图。C中模块化工具是函数依据上面需求分析,能够将这个系统设计分为以下六大模块。选课模块、按学分查找模块、按编号查找模块、查看课程模块、查看选课情况模块、课程输入模块、完成选择模块。模块图以下图1所表示。菜单选择模

9、块课程信息管理管理录入课程信息退出系统学生选课学生信息管 理录入学生信息完成选择模块 图1 系统功效模块图另外,程序用了两个结构体和五个全局变量N1,N2,kk1,kk2,kk3。五个全局变量是用来控制输入数据循环。两个结构体分别是课程信息结构体:struct couse/课程信息结构体int num1;/课程编号char name120;/课程名称char xinzhi30;/课程性质int ztime;/课程总课时int stime;/讲课课时int shiyan;/试验课时int score;/学分long int date;/开学学期int nelepeo;/课程已选人数int Mel

10、epeo;/课程人数上限struct couse * next;和存放学生信息结构体:struct student/学生信息结构体 int num2; char name220; int nelenum50;/已选课程编号 int nelen;/已选课程数量 struct student * next;void Ms() for(kk1=0;kk11100;kk1+) for(kk2=0;kk21200;kk2+) for(kk3=0;kk31200;kk3+);7系统具体设计7.1系统主菜单系统界面设计图包含六个选项,用户可依据自己需求选择不一样选项。系统界面设计图图2所表示。图2 系统界面

11、设计图系统模块图分为六大模块。分别是录入课程信息模块,课程信息管理模块,录入学生信息模块,学生信息管理模块,学生选课模块和退出系统模块。系统功效模块图以下图3所表示。录入课程信息课程信息管理录入学生信息学生信息管理学生选课退出系统主菜单图3系统功效模块图 图3 主菜单设计模块图当用户进入主菜单后,会显示有六个选项界面,需要用户从1-6个选项中选择一个选项来进行操作,若所选数非1-6,则会退出系统。系统主菜单步骤图图4所表示。开始依据n值调用各功效模块函数输入n,判定n是否是1-6定义nNYY调用完成结束图4 系统总步骤图该程序实现代码以下。int main()/主函数 int i; start

12、: printf(nttt欢迎使用学生选课系统!n); printf(n); printf(t主菜单:n);printf(t*n);printf(t* *n); printf(t* 1.录入课程信息 *n); printf(t* 2.课程信息管理 *n); printf(t* 3.录入学生信息 *n); printf(t* 4.学生信息管理 *n); printf(t* 5.学生选课 *n); printf(t* 6.退出系统 *n);printf(t* *n);printf(t*n); printf(n请输入菜单选项(16):); scanf(%d,&i); if(i6) printf(输入

13、错误,请重输: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

14、6: system(cls); printf(感谢使用本系统!nn再见!n); return 0;7.2录入课程信息录入课程信息有两个选项,录入课程和返回主菜单。录入课程信息界面设计图5所表示。图5录入课程信息界当用户进入录入课程后,会有两个选项,录入课程和返回主菜单。录入课程信息步骤图图6所表示。开始YNN定义nn=1?n=2?返回主菜单录入课程录入完成Y结束图6 录入课程信息步骤图实现该功效代码以下。void keyboardc()/录入课程子函数 struct couse *p1,*p2; N1=0; p1=p2=(struct couse*)malloc(sizeof(struct c

15、ouse); printf(课程编号 课程名称 课程性质 总课时 讲课课时 试验课时 学分 开课学期 人数上限n); scanf(%d%s%s%d%d%d%d%d,&p1-num1,p1-name1,&p1-xinzhi,&p1-ztime,&p1-stime,&p1-shiyan,&p1-score,&p1-date,&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(siz

16、eof(struct couse); scanf(%d%s%s%d%d%d%d%d,&p1-num1,p1-name1,&p1-xinzhi,&p1-ztime,&p1-stime,&p1-shiyan,&p1-score,&p1-date,&p1-Melepeo); p1-nelepeo=0; p2-next=NULL;void inputc()/录入课程主函数 int i; printf(ttt录入课程信息n); printf(n1.录入课程n); printf(2.返回主菜单n); printf(请选择(12):n); scanf(%d,&i); switch(i) case(1):ke

17、yboardc();break; case(2):break; 7.3课程管理课程管理有三个选项,新增课程,删除课程和返回主菜单。课程管理界面设计图7所表示。图7 课程管理界面课程管理能够选择增添或删除课程,若输入课程格式错误会显示错误,用户需要重新输入程管理步骤图图8所表示。输入课程信息新增或删除课程开始N结束显示失败保 存Y图8 课程管理步骤图实现该功效代码以下。void delc(int num1)/课程管理子函数(删除课程) struct couse *p1,*p2; if(head1=NULL) printf(n没有课程,无法删除!n); goto end; p1=head1; wh

18、ile(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(ttt课程信息管理n); printf(1.新增课程n); printf(2.删除课程n); print

19、f(3.返回主菜单n); printf(请选择(13):n); scanf(%d,&i); switch(i) case(1): incouse=(struct couse *)malloc(sizeof(struct couse); printf(课程编号 课程名称 课程性质 总课时 讲课课时 试验课时 学分 开课学期 人数上限n); scanf(%dn%sn%sn%dn%dn%dn%dn%dn%dn,&incouse-num1,&incouse-name1,&incouse-xinzhi,&incouse-ztime,&incouse-stime,&incouse-score,&incou

20、se-date,&incouse-Melepeo); incouse-nelepeo=0; insertc(incouse); break; case(2): printf(请输入要删除课程编号:n); scanf(%d,&num1); delc(num1); break; case(3):break; 7.4学生信息管理学生信息管理可选新增或删除学生信息,若全部不操作则可选返回主菜单。学生信息管理界面设计图9所表示。图9 学生信息管理界面学生信息管理有增加和删除学生信息,若选择此项,则会提醒用户输出入相关信息,若输入格式错误则会有提醒错误信息,当操作完成后会退回主菜单界面。学生信息管理界面步

21、骤图图10所表示。开始保留信息输入错误输入姓名,考号新增学生信息或删除学生信息退出结束NY图10 学生信息管理界面步骤图实现该功效代码以下。void inserts(struct student * incouse)/学生信息管理子函数(填加学生信息) struct student *p0,*p1,*p2; p1=head2; 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 num2) if

22、(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) hea

23、d2=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(ttt学生信息管理n); printf(1.新增学生信息n); printf(2.删除学生信息n); printf(3.返回主菜单n); printf(请选择(13):n); scanf(%d,&i); switch(i) case(1): incouse=(struc

24、t student *)malloc(sizeof(struct student); incouse-nelen=0; incouse-nelenum0=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; 7.5学生选课学生选课能够查询已选和可选课程,另外还有返回主菜单选项学生选课界面设计图11所表示。图11

25、 学生选课界面进入选课选项则会提醒用户输入学号然后再进行选课。若不选则能够退回主菜单。学生选课步骤图图12所表示。开始学生选课输入nn=1?Y查询可选课程输入学号Nn=2?Y返回主菜单查询完成查询完成n=3?N输入学号查询已选课程NNY结束图12 学生选课步骤图实现该功效代码以下。选课程序以下。用户要选课时,查询可选课程后会提醒输入所要选课程编号,然后程序会依据所选课程编号将所选课程信息储存。void elect(struct student * s)/选课 struct couse * p; int num1,i; printf(请输入要选课编号:n); scanf(%d,&num1); f

26、or(i=0;s-nelenumi!=0;i+); s-nelenumi=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!

27、=num2) printf(不存在你信息,请进入主菜单录入你信息!n); goto end; c=head1; printf(你可选课程编号:n); while(c!=NULL) for(t=0,i=0;s-nelenumi!=0;i+) if(c-num1=s-nelenumi) t=1; if(t=0 & (c-nelepeo!=c-Melepeo) printf(%dn,c-num1); j+; c=c-next; if(j=0) printf(你已选完全部课程,无法再多选!n); goto end; printf(选课(y/n)?:n); getchar(); e=getchar();

28、 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-nelenumi!=num1;i+);

29、for(j=i;p-nelenumj!=0;j+) p-nelenumj=p-nelenumj+1; p-nelenum-j=0; (p1-nelepeo)-; printf(退课成功!n);查询已选课程代码以下。首先输入学号,若系统中无统计,则会提醒不存在该信息,请用户录入该信息,然后用goto语句跳转到主菜单界面。若有统计,则继续输入课程编号,若未选此课,则会提醒你还没有选这个课程。void hcheak()/学生选课子函数(查询已选课程) char c; struct couse * p0; struct student * p; int num2,i,f=0; printf(请输入学号

30、: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-nelenum0=0) printf(你还没选课!n); goto end; for(i=0;p-nelenumi!=0;i+) printf(%dn,p-nelenumi); p0=head1; while(p0-num1!=p-nelenumi) p0=p0-next; f=f+p0-score; print

31、f(总学分:%dn,f); printf(是否进行退课(y/n)?); getchar(); c=getchar(); while(c=y) back(p); printf(继续退课(y/n)?); getchar(); c=getchar(); (p-nelen)-; end:;选课主界面程序以下。用printf输出界面,用switch语句选择调用对应函数以实现选择多种情况。void elective()/学生选课主函数 int i; printf(ttt学生选课n); printf(1.查询可选课程n); printf(2.查询已选课程n); printf(3.返回主菜单n); print

32、f(请输入(13):n); scanf(%d,&i); switch(i) case(1):cheak();break; case(2):hcheak();break; case(3):break; 8系统调试和测试8.1调试在调试程序过程中,首先碰到了部分编程序时通病,比如常常性遗漏了语句尾分号,还偶然遗漏大括号,造成程序不能正常编译。其次在编写函数模块时,因为之前设计考虑得不足,会有部分功效无法实现,最终只有删掉这些无法实现设计模块。录入课程信息以下图13所表示。图13 录入课程信息课程信息管理以下图14所表示。图14新增课程删除课程以下图15所表示。图15删除课程录入学生信息以下图16所表示。图16录入学生信息新怎学生信息以下图17所表示。图17新增学生信息删除学生信息以下图18所表示。图18删除学生信息查询可选课程以下图19所表示。图19 查询可选课程查询已选课程以下图20所表示。图20 查询已选课程退出系统以下图21所表示。图21 退出系统8.2测试测试过程中测试了菜单部分功效是否能正常实现和输入数据是否能储存。

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 学术论文 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服