ImageVerifierCode 换一换
格式:DOC , 页数:16 ,大小:134.51KB ,
资源ID:9737038      下载积分:8 金币
验证码下载
登录下载
邮箱/手机:
图形码:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

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

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

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请。


权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4009-655-100;投诉/维权电话:18658249818。

注意事项

本文(C语言课程设计报告学生成绩管理系统{修}.doc)为本站上传会员【鼓***】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

C语言课程设计报告学生成绩管理系统{修}.doc

1、内蒙古科技大学课程设计论文 内蒙古科技大学 本科生课程设计论文 题 目:学生成绩管理系统 学生姓名:胡书培 学 号:1067111106 专 业:计算机科学与技术 班 级:10级—计算机1班 指导教师:周李涌 2010年 12 月 30 日 目录 内蒙古科技大学课程设计任务书 3 学生成绩管理系统 4 【摘要】 4 1.论文题目:学生成绩管理系统 4 2.技术参数、设计步骤: 4 3.设计理论分析方法: 5 4.设计结论及分析: 5 4.1 各个函数

2、功能简单分析: 5 4.1.1主菜单函数(main): 5 4.1.2输入函数(input): 5 4.1.3输出函数(display): 6 4.1.4查找(find): 6 4.1.5修改(change): 6 4.1.6删除(del): 6 4.1.7添加(add): 6 4.1.8读入(read): 6 4.1.9保存(save): 6 4.1.10排序(sort): 6 4.1.11学号排序(sortx): 7 4.1.12不及格输出(no_pass): 7 4.1.13输出(shuchu): 7 5.参考文献: 7 6. 附录: 8 6.1 程序部分

3、 8 内蒙古科技大学课程设计任务书 课程名称 C语言课程设计 设计题目 学生成绩管理系统 指导教师 周李涌 时间 2010.12.27——2010.12.31 一、教学要求 1. 巩固和加深学生对C语言课程的基本知识的理解和掌握 2. 掌握C语言编程和程序调试的基本技能 3. 利用C语言进行基本的软件设计 4. 掌握书写程序设计说明文档的能力 5. 提高运用C语言解决实际问题的能力 二、设计资料及参数 每个学生在教师提供的课程设计题目中任意选择一题,独立完成,题目选定后不可更换。 某班学生成绩管理,包括以下功能:

4、 v 从键盘输入包括学号、姓名、各门课程成绩(不少于2门),并将其保存在磁盘文件student里 v 打开文件后,计算每个人的总分和平均分,排序并保存 v 具有在文件中进行单项查询或多项查询的功能(即能够按照给定的关键字,如姓名等找出满足条件的纪录) v 具有输出文件数据信息的功能 三、设计要求及成果 1. 分析课程设计题目的要求 2. 写出详细设计说明 3. 编写程序代码,调试程序使其能正确运行 4. 设计完成的软件要便于操作和使用 4. 设计完成后提交课程设计报告 四、进度安排 第一天  选择课程设计题目,分析课题的要求 第二天  编程 第三天  编程及调试

5、第四天  写课程设计报告 第五天  提交课程设计报告(打印稿及电子稿) 五、评分标准 1. 根据平时上机考勤、表现和进度,教师将每天点名和检查 2. 根据课程设计完成情况,必须有可运行的软件。 3. 根据课程设计报告的质量,如有雷同,则所有雷同的所有人均判为不及格。 六、建议参考资料 1.《C语言程序设计》,谭浩强,清华大学出版社 2.《C语言程序设计课程设计》,刘振安,机械工业出版社 学生成绩管理系统 【摘要】 通过课程设计,让我对C语言有了更深的理解,让我们把学到的理论应用于具体实践中,锻炼了我们各方面的能力,从而让我们更快提高。通过一些简单函数的叠加构成了功

6、能比较完备的学生成绩管理系统,从输入到处理再到输出,你将体会到完美的真正含义。学生成绩管理系统具有以下简单功能: 1.从键盘输入包括学号、姓名、各门课程成绩(不少于2门),并将其保存在磁盘文件里 2.打开文件后,计算每个人的总分,排序并保存 3.具有在文件中进行单项查询或多项查询的功能(即能够按照给定的关键字,如姓名等找出满足条件的纪录) 4.具有输出文件数据信息的功能 1.论文题目:学生成绩管理系统 2.技术参数、设计步骤: 本程序包含输入(input)、输出(display)、查找(find)、修改(change)、删除(del)、添加(add)、读入(read)、保存(

7、save)等基本功能。先分别定义各种全局函数和全局变量now,同时定义结构体及结构体数组(本程序为实现简单操作暂定义长度为3)。其中now作为现有学生信息的一个标记作用尤为重要。每次执行完函数就返回主菜单。共含有四个开关语句,依次在main,display,find,change中,使界面更友好,用户操作更简单。设计共分四步完成,依次为简单设计,添加细节,上机调试,先改错再修改。遇到的问题可以查资料或向老师提问。 3.设计理论分析方法: 应有全局的概念,拿到题目首先进行总体功能分析,只有对整体功能有了全局把握才能去里自己用那部分知识进行编写。这个阶段好比盖房子,如果这个阶

8、段做好了,说明房子已改好了。剩下任务就是怎么去装修了。确定了大体方向接下来就是功能实现阶段了,即所谓装修阶段。同样需要逐一地先写出能实现此功能的简单程序。比如学生成绩管理系统,先写出最简单的输入、输出、排序等功能函数。然后通过简单函数的互相调用、嵌套构成一个新功能的复杂函数。淡然这中间要加很多其他东西,这就需要我们多看书,多问老师同学啦。 等到所有功能都能“正常”(按提示正确输入)实现,再考虑一些细节问题,例如:如果所有都能简单运行,可是有些时候有些输入错误或正确它都运行,这就需要我们通过改写程序使之在正确输入时运行,在错误输入时给出出错提示。就像性别问题,输入M/W时运行,输入其他就不让它

9、运行,同时给出正确输入的提示。这样就好很多了。后面的一一修改就可以了。同时还要考虑到见名知意,如: 输入(input)、输出(display)、查找(find)、修改(change)、删除(del)、添加(add)、读入(read)、保存(save)、排序(sort)、按学号排序(sortx)、不及格(no_pass)、输出(shuchu)。当然还有其他问题需要注意,在这里不一一细说。 4.设计结论及分析: 4.1 各个函数功能简单分析: 4.1.1主菜单函数(main): 主函数为一个死循环,前几个是功能实现函数,只有9是退出。也就是说每执行完一个函数,他就自动返回主菜单。只有选

10、择9(退出)时才跳出循环。当然每选择一次它就自动清空屏幕,所以运行结果更直观。 4.1.2输入函数(input): 先输入要添加的学生数量n,同时now标记现有学生的数量。执行n次循环,输入n个学生的信息;其中输入性别时只有为M/W(M为男,W为女,均大写)时才跳出循环。如果出错,有提示信息。最后自动求和并保存。 4.1.3输出函数(display): 三部分1.按总分名次输出2.按学号顺序输出3.输出有不及格课程的学生 4.1.4查找(find): 查找分为按学号查找和按姓名查找,查找成功就输出,查找失败就返回,输出提示信息继续输入。 4.1.5修改(change): 输入

11、学号,然后选择修改项,修改完后,提示用户“是否继续修改”,只有输入N/n时退出,输入其它字符都是继续。 4.1.6删除(del): 输入要删除学生的学号,如果找到就删除其信息,并提示用户删除成功,如果没找到就提示用户删除失败。 4.1.7添加(add): 根据信息总容量(结构体数组的长度)和第一次输入的信息量判断是否能继续添加。如果添加后信息已满,则提示用户不能继续添加,同时屏蔽了添加选项。 4.1.8读入(read): 从文件读入,避免了用户多次大量输入数据。 4.1.9保存(save): 每次执行完修改信息包括添加、录入、修改、删除等都需要保存信息。当然在每个修改函数最后都

12、需要调用一下保存函数。 4.1.10排序(sort): 按总成绩名次排序(冒泡法排序)。n为要排序的学生数量,为形参。 4.1.11学号排序(sortx): 按学号先后顺序进行排序(冒泡法排序)。n为要排序的学生数量,为形参。 4.1.12不及格输出(no_pass): 输出不及格的学生信息。 4.1.13输出(shuchu): 输出第n个学生信息。 5.参考文献: (1).《C语言程序设计》,谭浩强,清华大学出版社 (2).《C语言程序设计课程设计》,刘振安,机械工业出版社

13、 6. 附录: 6.1 程序部分: #include #include #include #include #define max 3 void input(); void display(); void find(); void change(); void del(); void read(); void save(); void add(); void sort(int n); void sortx(int n); void shuchu(int n); void

14、no_pass(); int now=0;/*标记位*/ struct student { int num; char name[20]; char sex; int NO; float score1; float score2; float sum; };struct student stu[max+1]; void main()/*主函数(菜单)*/ { int as; do { printf("\n\t\t\t欢迎使用学生成绩管理系统\n\n"); printf("\n\t\t\t\t1.录入学员信息\n\t\t\t\t2.

15、显示学员信息\n\t\t\t\t3.查找学员信息\n\t\t\t\t4.修改学员信息\n\t\t\t\t5.删除学员信息\n\t\t\t\t6.添加学员信息\n\t\t\t\t7.读入学员信息\n\t\t\t\t8.保存学员信息\n\t\t\t\t9.退出"); printf("\n\n\n\t\t\t\t请选择"); scanf("%d",&as); switch(as) { case 1:system("cls");input();break; case 2:system("cls");display();break; case 3:system(

16、"cls");find();break; case 4:system("cls");change();break; case 5:system("cls");del();break; case 6:system("cls");add();break; case 7:system("cls");read();break; case 8:system("cls");save();break; case 9:system("cls");exit(0); } } while(1); } void input()/*输入函数*/ { in

17、t i,n,j; for(i=0;;i++) { printf("\n请输入添加的学生数量(在%d以内):",max-now); scanf("%d",&n); if(n>max)printf("\n请确保添加的数量在%d以内\t!!!",max); if(n<=max)break; } now=n; for(i=0;i

18、 scanf("%d",&stu[i].num); getchar(); printf("\n输入学生的姓名:"); gets(stu[i].name); printf("\n请输入学生的性别(M/W):"); for(j=0;;j++) { stu[i].sex=getchar(); if(stu[i].sex=='M'||stu[i].sex=='W')break; else printf("\n\t\t\t请确保输入性别的正确性(区分大小写)!!!"); getchar(); }

19、printf("\n请输入学生成绩1:"); scanf("%f",&stu[i].score1); printf("\n请输入学生成绩2:"); scanf("%f",&stu[i].score2); stu[i].sum=stu[i].score1+stu[i].score2; } sort(n); save(); system("cls"); } void display()/*整体输出函数*/ { int as,i; printf("\n\t\t\t班级学生成绩列表\n\n\n"

20、); printf("\n\t\t\t\t请选择\n\n\t\t\t1.按名次输出\n\t\t\t2.按学号输出\n\t\t\t3.不及格的学生信息\n\t\t\t"); scanf("%d",&as); switch(as) { case 1:sort(now);for(i=0;i

21、 find()/*查询函数*/ { int num,as,i; char name[20]; printf("\n\t\t\t请选择\n\n\n"); printf("\n\t\t\t1.按学号查找\n\t\t\t2.按姓名查找\n\t\t\t"); scanf("%d",&as); switch(as) { case 1:system("cls");printf("请输入要查找的学号:"); do { scanf("%d",&num); for(i=0;i

22、) { if(num==stu[i].num) { shuchu(i);break; } } if(i>=now) printf("\n\t\t该生信息不存在!!!请重新输入学号:"); }while(i>=now);break; case 2:system("cls");getchar();printf("请输入要查找的学生姓名:"); do { gets(name); for

23、i=0;i=now) printf("\n\n\t\t\t该生信息不存在!!!请重新输入姓名:"); }while(i>=now);break; } } void change()/*修改函数*/ { int num,as,j,i,m; char a;

24、printf("\n\t\t\t请输入要修改的学生的学号:"); scanf("%d",&num); for(i=0;i

25、canf("%d",&as); switch(as) { case 1:printf("请输入新的学号:");scanf("%d",&stu[i].num);break; case 2:printf("请输入新的姓名:");getchar();gets(stu[i].name);break; case 3:printf("请输入新的性别:");getchar(); for(m=0;;m++) {

26、 stu[i].sex=getchar(); if(stu[i].sex=='M'||stu[i].sex=='W')break; else printf("\n\t\t\t请确保输入性别的正确性(区分大小写)!!!"); getchar();

27、 }break; case 4:printf("请输入新成绩1:");scanf("%f",&stu[i].score1);break; case 5:printf("请输入新成绩2:");scanf("%f",&stu[i].score2);break; } stu[i].sum=stu[i].score1+stu[i].score2; printf("\n是否继续修改该生信息?(Y/N)"); getchar(); a=getchar(); if(a=='N'|

28、a=='n')break; } sort(now); save(); break; } } if(i>=now) printf("\n\n\t\t\t\t学号输入有误!!!\n\n"); } void del()/*删除函数*/ { int num,i; printf("\n\t\t\t输入要删除的学生学号"); scanf("%d",&num); for(i=0;i<=now;i++) { if(i>=now) { printf("

29、\n\n\n\t\t\t学号输入有误!!!删除失败!!!\n\n"); break; } if(stu[i].num==num) { if(i==now-1) now-=1; else { stu[i]=stu[now-1]; now-=1; } printf("\n\n\t\t\t删除成功!!!\n\n"); sort(now); break; } } save(); } void a

30、dd()/*添加函数*/ { char ch; int j; printf("\n\t\t\t\t还能添加%d个学生信息!!!\n\n",max-now); if(now

31、name); printf("\n输入学生的性别(M/W):"); for(j=0;;j++) { stu[now].sex=getchar(); if(stu[now].sex=='M'||stu[now].sex=='W')break; else printf("\n\t\t\t请确保输入性别的正确性(区分大小写)!!!"); getchar(); } printf("\n输入学生的成绩1:"); scanf("%f",&stu[now].score1);

32、 printf("\n输入学生的成绩2:"); scanf("%f",&stu[now].score2); stu[now].sum=stu[now].score1+stu[now].score2; now=now+1; sort(now); if(now>=max) { printf("\n\n\n\t\t存储空间已满无法继续添加!!!\n\n"); break; } printf("\n\t\t\t是否继续添加?(Y/N)"); g

33、etchar(); ch=getchar(); } while(ch!='n'||ch!='n'); } } void save()/*文件保存函数*/ { FILE *fp;/*fp为文件指针*/ int i; if((fp=fopen("stu_infer","wb"))==NULL) { printf("\n\n\t\t\t文件打开失败!!!"); return; } for(i=0;i

34、nt),1,fp)!=1) printf("\n\n\t\t\t文件保存错误!!!"); fclose(fp); } void read()/*从磁盘读入函数*/ { int i; FILE *fp;/*fp为文件指针*/ fp=fopen("stu_infer","rb"); for(i=0;i

35、struct student temp; int i,j; for(j=0;j

36、student temp; int i,j; for(j=0;jstu[i+1].num) { temp=stu[i]; stu[i]=stu[i+1]; stu[i+1]=temp; } } } void no_pass()/*输出有不及格课程的学生的函数*/ { int i; printf("\n\t\t\t显示有不及格课程的学生信息:"); for(i=0;i

37、w;i++) if(stu[i].score1<60||stu[i].score2<60) shuchu(i); } void shuchu(int n)/*输出第n个学生信息的函数*/ { printf("\n\t学号\t姓名\t性别\t名次\t成绩1\t成绩2\t总成绩\n"); printf("\t%d\t%s\t%c\t%d\t%.2f\t%.2f\t%.2f\n",stu[n].num,stu[n].name,stu[n].sex,stu[n].NO,stu[n].score1,stu[n].score2,stu[n].sum); } 16

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

关于我们      便捷服务       自信AI       AI导航        抽奖活动

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

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

gongan.png浙公网安备33021202000488号   

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

关注我们 :微信公众号    抖音    微博    LOFTER 

客服