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

开通VIP
 

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

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  
声明  |  会员权益     获赠5币     写作写作

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

注意事项

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

C语言学生成绩标准管理专业系统设计方案报告.doc

1、计算机科学和技术学院课程设计汇报 第二学期课程名称 C语言程序设计 题 目 学生成绩管理系统 学生姓名 XXX 学 号 XXX 专业班级 XXX 指导老师 XXX 合 作 者 XXX 6月 30日学生成绩管理系统本程序可实现对学生语数外三门课程成绩录入和保留。1、 设计目标 本程序意在训练读者基础编程能力,了解管理信息系统开发步骤,熟悉C语言多种语法、编写步骤、和能够熟练利用多种算法、和多种函数使用。2、 功效描述本程序可实现功效:(1) 录入学生成绩(2) 输出学生成绩(3) 添加学生成绩信息(4) 删除指定学生成绩信息(5) 根据要求对学生成绩信息进行排序(6) 依据学号查询指定学生成绩(

2、7) 将学生成绩信息以文件形式保留3、 总体设计3.1具体实现 main()函数:程序首先调用menu()函数,显示出系统主菜单,然后将menu()函数返回从用户读取选项k值给予k,接着进入switchcase语句进入对应选项函数,若输入错误没有该选项则给出提醒(default)以上过程为一个死循环,直到用户输入0为止。menu()函数:在屏幕上打印选项名称,然后用一个int类型变量接收从用户输入选项,最终将其return至主函数。score *creatlink()函数:创建链表关键实现步骤以下:print()函数:先令P=head,使p指向第一个节点,当head=!NULL时说明没有到链表

3、尾端,那么就输出p所指向结构数据,然后让p指向下一个节点,直到发觉p=NULL为止。而当head=NULL说明链表中不存在数据,直接停止输出。score *add()函数,添加新学生信息,具体实现旅程如步骤图所表示(图片制作时没有加Y/N判定,在判定图框中均为向左为真,向右为假):score *search()函数:用来查询学生成绩,传输给函数指向链表头指针,查询时,假如找到和输入相匹配学号则打印此学生,反之则输出“没有任何学生资料!”:score *sortdata()函数:该函数有学号、姓名、单科成绩排序(冒泡排序法),实施过程图:save()函数:用来保留数据,首先从用户输入取得要保留文

4、件名,然后定义一个指向文件指针,以读写方法打开文件。将写生信息依次存入文件。score *load()函数:用于读取数据,经过“r+”方法打开文件并判定是否打开成功。具体实现以下:score *statistics()函数:它能实现程序统计,经过switch-case语句选择统计方法,经过循环计算总分或平均分并打印出来,步骤全部是经过循环,让指针逐一遍历整个链表,读取对应数据并实现统计3.2数据结构设计数据结构:定义了一个包含学生成绩信息结构体(struct scorenode),学生信息包含学号(number)、姓名(name10)、语文、数学、英语成绩(chinese、mathmatic、

5、english)、和指向下一个结构体链表指针(struct scorenode *next)。 3.3函数功效描述main()函数:主函数功效关键是让程序选择将要进行操作,经过menu()函数返回选项进入其它函数实施。int menu(int k)函数:此函数显示主菜单内容,需要一个int类型变量作为输入要实施选项并返回给main()函数。score *creatlink()函数:此函数用于创建链表,为了节省内存空间,我们采取malloc()函数为结构体分配动态内存空间。另外考虑到学号不可能是0,所以用输入0 方法来判定是否结束输入,将最终结构体中指针指向NULL,并返回一个指向链表第一个结构

6、指针。void print(score *head)函数:此函数返回值为空,知识为了在stdout流(屏幕)上打印出学生成绩信息,需要一个指向链表头指针来逐一向后打印。score *add(score *head , score *stu)函数:为学生信息中添加新学生资料,然后重新排序(按学号),并返回头指针。传入函数head为链表头指针,stu指针指是要添加位置。score *search(score *head)函数:根据学号查找学生信息,需要链表头指针并返回指向被搜索学生指针。搜索原理就是从头向后面依次检索。score *dele(score *head)函数:删除指定学生资料。传入头指

7、针,在函数中创建变量储存要删除学生学号,然后从头向尾检索,直至找到该学生并将其删除,返回头指针。score *sortdata(score *head)函数:用于按要求(学号、姓名、单科成绩)排序,最终返回头指针,排序利用老师上课时讲过冒泡排序法。int save(score *p1)函数:将链表内数据以文件形式储存,传入p1指针一开始指向链表头,伴随储存次序一个一个地向后面指,直到NULL为止。函数内部定义一个指向文件指针*fp,用于写入文件。score *load(score *head)函数:读取文件数据,head为一个新建链表头指针,读取文件数据以后令其保留至新建链表之中,并返回头指针

8、。score *statistics(score *head)函数:统计成绩,能够统计总分、平均分、最高(低)分,返回操作后链表首地址(头指针)。4、 程序实现4.1源代码#include #include #include#include #define LEN sizeof(struct scorenode)#define DEBUG/*=数据结构=*/struct scorenodeint number;/学生学号char name10;/学生姓名float chinese;/语文成绩float mathmatic;/数学成绩float english;/英语成绩 struct scor

9、enode *next;typedef struct scorenode score;/定义结构体变量typedef struct scorenode *scoreptr;/定义结构体变量指针int n,k; /*n,k为全局变量,本程序中函数均能够使用它,分别用于记数和标识*/*=创建链表=*/*返回一个指向链表头指针*/score *creatlink()score*head;score *p1,*p2,*p3,*max;int i,j;float fen;char t10;n=0;p1=p2=p3=(score *)malloc(LEN);head=p3;/开辟一个新单元printf(请

10、输入学生资料,输0退出!n);repeat1: printf(请输入学生学号(学号应大于0):);/输入学号,学号应大于0scanf(%d,&p1-number);while(p1-numbernumber);/输入学号为字符或小于0时,程序报错,提醒重新输入学号 if(p1-number=0)goto end;/当输入学号为0时,转到末尾,结束创建链表else p3=head;if(n0)for(i=0;inumber!=p3-number)p3=p3-next;else printf(学号反复,请重输!n); goto repeat1;/*当输入学号已经存在,程序报错,返回前面重新输入*/

11、 printf(请输入学生姓名:);scanf(%s,&p1-name); /*输入学生姓名*/printf(请输入语文成绩(0100):); /*输入语文成绩,成绩应在0-100*/scanf(%f,&p1-chinese);while(p1-chinesechinese100)getchar();printf(输入错误,请重新输入语文成绩); /*输入错误,重新输入语文成绩直到正确为止*/ scanf(%f,&p1-chinese); printf(请输入数学成绩(0100):); /*输入数学成绩,成绩应在0-100*/ scanf(%f,&p1-mathmatic); while(p1

12、-mathmaticmathmatic100) getchar();printf(输入错误,请重新输入数学成绩); /*输入错误,重新输入数学成绩直到正确为止*/scanf(%f,&p1-mathmatic); printf(请输入英语成绩(0100):); /*输入英语成绩,成绩应在0-100*/ scanf(%f,&p1-english); while(p1-englishenglish100)getchar(); printf(输入错误,请重新输入英语成绩); scanf(%f,&p1-english); /*输入错误,重新输入英语成绩直到正确为止*/head=NULL;while(p1

13、-number!=0)n=n+1;if(n=1) head=p1;elsep2-next=p1;p2=p1;p1=(score *)malloc(LEN);printf(请输入学生资料,输0退出!n);repeat2:printf(请输入学生学号(学号应大于0):);scanf(%d,&p1-number); /*输入学号*/while(p1-numbernumber); /*输入学号为字符或小于0时,程序报错,提醒重新输入学号*/if(p1-number=0)goto end; /*当输入学号为0时,转到末尾,结束创建链表*/elsep3=head;if(n0)for(i=0;inumber

14、!=p3-number)p3=p3-next;else printf(学号反复,请重输!n);goto repeat2; /*当输入学号已经存在,程序报错,返回前面重新输入*/ printf(请输入学生姓名:);scanf(%s,&p1-name); /*输入学生姓名*/printf(请输入语文成绩(0100):);scanf(%f,&p1-chinese); /*输入语文成绩,成绩应在0-100*/while(p1-chinesechinese100)getchar();printf(输入错误,请重新输入语文成绩);scanf(%f,&p1-chinese); /*输入错误,重新输入语文成绩

15、直到正确为止*/printf(请输入数学成绩(0100):);scanf(%f,&p1-mathmatic); /*输入数学成绩,成绩应在0-100*/while(p1-mathmaticmathmatic100)getchar();printf(输入错误,请重新输入数学成绩);scanf(%f,&p1-mathmatic); /*输入错误,重新输入数学成绩直到正确为止*/printf(请输入英语成绩(0100):);scanf(%f,&p1-english); /*输入英语成绩,成绩应在0-100*/while(p1-englishenglish100)getchar();printf(输入

16、错误,请重新输入英语成绩);scanf(%f,&p1-english); /*输入错误,重新输入英语成绩直到正确为止*/end:p1=head;p3=p1;for(i=1;in;i+)for(j=i+1;jnext;if(max-numberp1-number)k=max-number;max-number=p1-number;p1-number=k; /*交换前后结点中学号值,使得学号大者移到后面结点中*/strcpy(t,max-name);strcpy(max-name,p1-name);strcpy(p1-name,t); /*交换前后结点中姓名,使之和学号相匹配*/fen=max-c

17、hinese;max-chinese=p1-chinese;p1-chinese=fen; /*交换前后结点中语文成绩,使之和学号相匹配*/fen=max-mathmatic;max-mathmatic=p1-mathmatic;p1-mathmatic=fen; /*交换前后结点中数学成绩,使之和学号相匹配*/fen=max-english;max-english=p1-english;p1-english=fen; /*交换前后结点中英语成绩,使之和学号相匹配*/max=head;p1=head; /*重新使max,p指向链表头*/ p2-next=NULL; /*链表结尾*/printf

18、(输入学生数为:%d个!n,n);return(head);/*=显示数据=*/*函数print,功效:显示学生成绩*/void print(score *head) score *p; if(head=NULL) printf(n没有任何学生资料!n); else printf(%dn,n); printf(-n);printf(|学号t|姓名t|语文t|数学t|英语t|n); printf(-n); /*打印表格域*/ p=head; do printf(|%dt|%st|%.1ft|%.1ft|%.1ft|n,p-number,p-name,p-chinese,p-mathmatic,p

19、-english); printf(-n); /*打印表格域*/ p=p-next;while (p!=NULL); /*=添加学生数据=*/*函数add,功效:追加学生资料,而且将全部学生资料按学号排序*/score *add(score *head,score *stu) score *p0,*p1,*p2,*p3,*max; int i,j; float fen; char t10; p3=stu=(score *)malloc(LEN); /*开辟一个新单元*/ printf(n输入要增加学生资料!); repeat4: printf(请输入学生学号(学号应大于0):); scanf(

20、%d,&stu-number); /*输入学号,学号应大于0*/ while(stu-numbernumber); /*输入错误,重新输入学号*/ if(stu-number=0) goto end2; /*当输入学号为0时,转到末尾,结束追加*/ else p3=head; if(n0) for(i=0;inumber!=p3-number) p3=p3-next; else printf(学号反复,请重输!n); goto repeat4; /*当输入学号已经存在,程序报错,返回前面重新输入*/ printf(输入学生姓名:); scanf(%s,stu-name); /*输入学生姓名*/

21、 printf(请输入语文成绩(0100):); scanf(%f,&stu-chinese); /*输入语文成绩,成绩应在0-100*/ while(stu-chinesechinese100) getchar(); printf(输入错误,请重新输入语文成绩); scanf(%f,&stu-chinese); /*输入错误,重新输入语文成绩直到正确为止*/ printf(请输入数学成绩(0100):); scanf(%f,&stu-mathmatic); /*输入数学成绩,成绩应在0-100*/ while(stu-mathmaticmathmatic100) getchar();prin

22、tf(输入错误,请重新输入数学成绩); scanf(%f,&stu-mathmatic); /*输入错误,重新输入数学成绩直到正确为止*/printf(请输入英语成绩(0100):);scanf(%f,&stu-english); /*输入英语成绩,成绩应在0-100*/while(stu-englishenglish100)getchar(); printf(输入错误,请重新输入英语成绩);scanf(%f,&stu-english); /*输入错误,重新输入英语成绩直到正确为止*/p1=head;p0=stu;if(head=NULL) head=p0;p0-next=NULL; /*当原

23、来链表为空时,从首结点开始存放资料*/ else /*链表不为空*/ if(p1-next=NULL) /*找到原来链表末尾*/ p1-next=p0; p0-next=NULL; /*将它和新开单元相连接*/ else while(p1-next!=NULL) /*还没找到末尾,继续找*/ p2=p1;p1=p1-next; p1-next=p0; p0-next=NULL; n=n+1;p1=head;p0=stu; for(i=1;in;i+) for(j=i+1;jnext; if(max-numberp1-number) k=max-number; max-number=p1-num

24、ber; p1-number=k; /*交换前后结点中学号值,使得学号大者移到后面结点中*/ strcpy(t,max-name); strcpy(max-name,p1-name); strcpy(p1-name,t); /*交换前后结点中姓名,使之和学号相匹配*/ fen=max-chinese; max-chinese=p1-chinese; p1-chinese=fen; /*交换前后结点中语文成绩,使之和学号相匹配*/ fen=max-mathmatic; max-mathmatic=p1-mathmatic; p1-mathmatic=fen; /*交换前后结点中数学成绩,使之和学

25、号相匹配*/ fen=max-english; max-english=p1-english; p1-english=fen; /*交换前后结点中英语成绩,使之和学号相匹配*/ max=head;p1=head ; /*重新使max,p指向链表头*/ end2: printf(现在学生数为:%d个!n,n); return(head);/*=查询数据=*/*函数search,功效:查询学生成绩*/score *search(score *head) int number; score *p1,*p2; printf(输入要查询学生学号:); scanf(%d,&number);while(nu

26、mber!=0) if(head=NULL) printf(n没有任何学生资料!n);return(head); printf(-n); printf(|学号t|姓名t|语文t|数学t|英语t|n); printf(-n); p1=head; while(number!=p1-number&p1-next!=NULL) p2=p1;p1=p1-next; if(number=p1-number) printf(|%dt|%st|%.1ft|%.1ft|%.1ft|n,p1-number,p1-name,p1-chinese,p1-mathmatic,p1-english); printf(-n

27、); else printf(%d不存在此学生!n,number); printf(输入要查询学生学号,); scanf(%d,&number);printf(已经退出了!n);return(head);/*=删除数据=*/*函数dele,功效:删除学生资料*/score *dele(score *head) score *p1,*p2; int number; printf(输入要删除学生学号(输入0时退出):); scanf(%d,&number); getchar(); while(number!=0) /*输入学号为0时退出*/ if(head=NULL) printf(n没有任何学生

28、资料!n); return(head); p1=head; while(number!=p1-number&p1-next!=NULL) /*p1指向不是所要找首结点,而且后面还有结点*/ p2=p1;p1=p1-next; /*p1后移一个结点*/ if(number=p1-number) /*假如找到了*/ if(p1=head) head=p1-next; /*若p1指向是首结点,把地二个结点地址给予head*/ else p2-next=p1-next; /*不然将下一个结点地址 赋给前一结点地址*/ printf(删除:%dn,number);n=n-1; else printf(%

29、d不存在此学生!n,number); /*找不到该结点*/ printf(输入要删除学生学号:); scanf(%d,&number); getchar(); #ifdef DEBUG printf(已经退出了!n);#endifprintf(现在学生数为:%d个!n,n); return(head);/*=排序=*/*定义排序函数。此函数带回一个指向链表头指针*/score *sortdata(score *head) score *p,*max;int i,j,x;float fen;char t10;if(head=NULL)printf(n没有任何学生资料,请先建立链表!n);retu

30、rn(head); /*链表为空*/max=p=head;for(i=0;i80;i+)printf(*);printf(1按学生学号排序t2按学生姓名排序t3按语文成绩排序n);printf(4按数学成绩排序t5按英语成绩排序tn);for(i=0;i80;i+)printf(*);printf(请选择操作:);scanf(%d,&x); /*选择操作*/getchar();switch(x) /*用switch语句实现功效选择*/case 1 : for(i=1;in;i+)for(j=i+1;jnext;if(max-numberp-number)k=max-number;max-num

31、ber=p-number;p-number=k; /*交换前后结点中学号值,使得学号大者移到后面结点中*/strcpy(t,max-name);strcpy(max-name,p-name);strcpy(p-name,t); /*交换前后结点中姓名,使之和学号相匹配*/fen=max-chinese;max-chinese=p-chinese;p-chinese=fen; /*交换前后结点中语文成绩,使之和学号相匹配*/fen=max-mathmatic;max-mathmatic=p-mathmatic;p-mathmatic=fen; /*交换前后结点中数学成绩,使之和学号相匹配*/fen=max-english;max-english=p-english;p-english=fen; /*交换前后结点中英语成绩,使之和学号相匹配*/max=head;p=head;/*重新使max,p指向链表头*/print(head);break;/*打印值排序后链表内容*/case 2 :for(i=1;in;

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

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

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

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

gongan.png浙公网安备33021202000488号   

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

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

客服