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

开通VIP
 

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

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

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

注意事项

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

运动会分数统计数据结构课程设计(含源代码).doc

1、计算机学院信管专业数据结构课程设计题 目: 运动会分数统计 班 级: 姓 名: 学 号: 同组人姓名: 起 迄 日 期: 课程设计地点: 指导教师: 评阅意见:成绩评定:评阅人: 日期:完成日期:2013年12月目录1、需求分析022、概要设计033、详细设计044、调试分析和测试结果055、总结136、参考文献147、致谢148、附录141、需求分析(1)任务:参加运动会有n个学校,学校编号为1n。比赛分成m个男子项目,和w个女子项目。项目编号为男子1m,女子m+1m+w。不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些取前五名或

2、前三名由学生自己设定。(m=20,n=20)(2)功能要求:a).可以输入各个项目的前三名或前五名的成绩;b).能统计各学校总分,c).可以按学校编号、学校总分、男女团体总分排序输出;d).可以按学校编号查询学校某个项目的情况;可以按项目编号查询取得前三或前五名的学校。(3)规定:输入数据形式和范围:20以内的整数(如果做得更好可以输入学校的名称,运动项目的名称)(4)输出形式:有中文提示,各学校分数为整形(5)界面要求:有合理的提示,每个功能可以设立菜单,根据提示,可以完成相关的功能要求。(6)存储结构:学生自己根据系统功能要求自己设计,但是要求运动会的相关数据要存储在数据文件中。(7)测试

3、数据:要求使用1、全部合法数据;2、整体非法数据;3、局部非法数据。进行程序测试,以保证程序的稳定。测试数据及测试结果请在上交的资料中写明;2、概要设计(1)文字分析本课设要求输入信息,统计分数,执行排序与查找功能,在要求中没有在建立数据之后进行插入和删除操作,而在排序和查找过程中有许多的随机读取数据操作,因此使用顺序结构而不用链表。由于各个要求属性具有一定的联系,在定义数据时使用结构体和结构体数组来存储信息数据。考虑到程序的要求在设计函数时将学校个数和项目个数设计为可变的数据,为方便使用设计菜单函数(menu),而由于要求将信息存储在文件中故设计文件的存储(savetofile)与读取函数(

4、readfromfile),信息输入函数(input)在输入基本信息后由系统统计总分的内容并全部存入文件file中,在接下来的函数中开始都需要读取文件中的信息,信息的输出(output)输出输入函数中统计后的各项信息,在排序输出(sortput)中使用冒泡排序法进行不同关键字的排序,查询函数(search)采用顺序表的查找来完成。开始进入主菜单菜单选项(04)1.信息输入2.统计输出3.排序输出4.信息查询5.退出结束3、详细设计(1)项目数据表:运动会系统先制定本次运动会所需的参赛项目。本数据表根据要求设计存储每个项目的编号、要取的名次、各个名次名称及各名次对应的分数。用于对以后项目情况的统

5、计已及查询。其中inum,top,range由输入信息输入,而mark有range和top决定。typedef struct int inum; /*项目编号*/ int top; /*取名次的数目*/ int range5; /*名次*/ int mark5; /*分数*/itemnode; /*存放项目信息*/(2)学校数据表:本数据表根据要求储存了各个参赛学校的总体情况,包括学校的编号、学校总分、男子团体总分、女子团体总分,并且包括项目数据数组tn。其中snum和tn中部分数据由输入信息输入,而其他三项内容score,mscore,wscore将由系统进行自动统计。typedef str

6、uct int snum; /*学校编号*/ int score; /*学校总分*/ int mscore; /*男团体总分*/ int wscore; /*女团体总分*/ itemnode tM+W; /*项目数组*/snode; /*存放学校信息*/snode aN; /* 定义一个学校数组*/ 这二个数据表相关联接,an中包括tn,形成一个整体。(3)模块划分1、Void menu(int n,int m,int w) 功能是提供界面窗口2、Void savetofile() 功能是保存输入的运动会信息到file文件3、Void readfromfile() 功能是从file文件中读取运

7、动会信息4、Void input(int n,int m,int w) 功能是输入信息并统计5、Void output(int n,int m,int w) 功能是按学校、项目输出统计信息6、Void sortput(int n,int m,int w) 功能是按四种方法排序并输出结果7、Void search(int n,int m,int w) 功能是按两种方法查询并输出结果4、调试分析与测试结果(1)测试数据测试取学校个数为3,男子项目个数2.女子项目个数1项目学校编号1(男)编号2(男)编号3(女)取前3取前5取前5编号1名次31、43、4编号2名次22、51、5编号3名次132(2)

8、测试结果1、主菜单界面2、信息输入运行测试a).信息输入b).输入完成3、统计输出运行测试a).统计输出b).统计输出完毕4、排序输出运行测试a).选择排序输出形式b).按学校编号输出c).按学校总分输出d).按男团总分输出d).按女团总分输出5、信息查询运行测试a).选择信息查询方式b).按学校编号查询c).按项目编号查询6、退出系统运行测试5、总结通过为期四天的课程设计,我对数据结构这门课程有了更深一步的了解,使我对数据结构这门课程掌握以及运用更加灵活。虽然是应用C语言来编写程序,但却深刻的体现了数据结构对编程的重要性。这次课程设计运用C语言与数据结构知识,编写一个运动会分数统计系统。其中

9、遇到了不少问题,因为对数据结构这一门课程掌握不够熟练以及平时自己在编写一些普通常见的程序时只是运用单一的知识而课程设计却需要将各个方面的内容联系结合,例如文件与程序的结合,输入、输出、统计、查找的综合应用等,因此真正的程序设计必须先有一个正确的算法思想,运用正确的数据结构和编程语言,灵活的运用并联系几个方面的内容。通过课程设计也使我认识到,要学好编程,仅学习书本上的知识是不够的,还要有较强的实践能力。因为我们学习知识就是为了实践。而只有多实践,多编写程序,才能更好的理解与掌握书本上的东西6、参考文献1 严蔚敏,吴伟民;数据结构(C语言版),清华大学出版社,2007年2 王裕明;数据结构与程序设

10、计,清华大学出版社,2010年3 谭浩强;C语言程序设计(第三版),北京航空航天大学出版社,2005年4 李建学;数据结构课程设计案例精编(用C/C+描述),清华大学出版社,2007年5 催俊凯;计算机软件基础,机械工业出版社,2007年6 7、致谢本次试验能够如期完成,主要是要感谢席老师课堂上的讲解以及指导,才能使我对数据结构这门课程有较为深入的理解与掌握,才能在本次课程设计中得以运用。再加上课程设计过程中的程序设计建议,才使得这次课程设计中所遇到的问题能够较快的解决其次,我还要感谢和我一组的赵咏荔同学,通过两个人的共同协作,才使得本次课程设计能够较好的完成。同时,还要感谢平时课堂上以及课堂

11、外给我帮助的同学们,能够热心的为我解答我所存在的疑问,并为我的程序提出一些建议。8、附录源代码:#include#include#include #define N 20 /*学校最大数目*/ #define M 20 /*男子项目最大数目*/ #define W 20 /*女子项目最大数目*/typedef struct int inum; /*项目编号*/ int top; /*取名次的数目*/ int range5; /*名次*/ int mark5; /*分数*/itemnode; /*存放项目信息*/typedef struct int snum; /*学校编号*/ int scor

12、e; /*学校总分*/ int mscore; /*男团体总分*/ int wscore; /*女团体总分*/ itemnode tM+W; /*项目数组*/snode; /*存放学校信息*/snode aN; /* 定义一个学校数组*/void menu(int n,int m,int w) /*菜单函数*/ int c; void input(int n,int m,int w);void output(int n,int m,int w);void sortput(int n,int m,int w);void search(int n,int m,int w);printf(ttt欢迎

13、使用ttttnn); printf(t*运动会分数统计系统*nn); printf(tt*1.信息输入*n); printf(tt*2.统计输出*n); printf(tt*3.排序输出*n); printf(tt*4.信息查询*n); printf(tt*0.退出系统*nn); printf(=nn);printf(请选择要实现步骤的编号(0-4):); scanf(%d,&c);switch(c) case 1: input(n,m,w);break; case 2: output(n,m,w);break; case 3: sortput(n,m,w);break; case 4: se

14、arch(n,m,w);break; case 0:printf(谢谢使用,再见!n); exit(0); default: printf(输入错误,请重试!n);menu(n,m,w); void savetofile() /*信息存入文件file*/FILE *fp; int i; if(fp=fopen(file.txt,w)=NULL) printf(cannot open the filen);return; for(i=0;iN;i+) if(ai.snum!=0)if(fwrite(&ai,sizeof(snode),1,fp)!=1)printf(file write erro

15、rn);return; fclose(fp);void readfromfile() /*信息从文件file中取出*/ int i;FILE *fp; if(fp=fopen(file.txt,rb)=NULL) printf(cannot open the filen);return; for(i=0;iN;i+)fread(&ai,sizeof(snode),1,fp); fclose(fp);void input(int n,int m,int w) /*1.信息输入*/int i,j,s,k,q=0; for(i=0;in;i+) printf(学校编号:); scanf(%d,&ai

16、.snum); /*输入学校信息*/ for(j=0;jm+w;j+) printf(项目编号:); scanf(%d,&ai.tj.inum);printf(项目取前3名或前5名(3或者5):); scanf(%d,&ai.tj.top);if(ai.tj.top=3)printf(获得名次个数(1-3):);elseprintf(获得名次个数(1-5):); scanf(%d,&k); /*输入项目信息*/ for(s=0;sk;s+) if(ai.tj.top=3)printf(所获名次(1-3):);elseprintf(所获名次(1-5):); scanf(%d,&ai.tj.ran

17、ges); /*输入所获名次信息*/ printf(n); for(i=0;in;i+) ai.score=0; ai.mscore=0; ai.wscore=0; /*初始化分数*/for(i=0;in;i+)for(j=0;jm+w;j+)for(s=0;s5;s+) if(ai.tj.top=3)switch(ai.tj.ranges) case 0: ai.tj.marks=0; break; case 1: ai.tj.marks=5; break; case 2: ai.tj.marks=3; break; case 3: ai.tj.marks=2; break;else if(

18、ai.tj.top=5)switch(ai.tj.ranges) case 0: ai.tj.marks=0; break; case 1: ai.tj.marks=7; break; case 2: ai.tj.marks=5; break; case 3: ai.tj.marks=3; break; case 4: ai.tj.marks=2; break; case 5: ai.tj.marks=1; break;else printf(信息有误!);printf(n);exit(0);ai.score=ai.score+ai.tj.marks; /*记学校总分*/if(j=m-1)ai

19、.mscore=ai.mscore+ai.tj.marks; /*记男子团体总分*/elseai.wscore=ai.wscore+ai.tj.marks; /*记女子团体总分*/printf(输入完毕!返回? 1是 2否n); /*返回菜单*/scanf(%d,&q);printf(n);if(q!=1)printf(不能再添加信息!);printf(n);savetofile(); /*将信息存入文件file*/menu(n,m,w);void output(int n,int m,int w) /*2.统计输出*/ readfromfile();int i,j,s,q=0; for(i=

20、0;in;i+) /*显示结果*/printf(学校编号:%d 学校总分:%d 男团总分:%d 女团总分:%dn,ai.snum,ai.score,ai.mscore,ai.wscore); for(j=0;jm+w;j+)printf(项目编号:%d 所取名次数量:%dn,ai.tj.inum,ai.tj.top);for(s=0;s5;s+) if(ai.tj.ranges!=0)printf(名次:%d 分数:%dn,ai.tj.ranges,ai.tj.marks);printf(n);printf(n);printf(统计完毕!返回? 1是 2否); /*返回菜单*/scanf(%d

21、,&q);printf(n);if(q!=1)printf(统计已经结束!);printf(n); menu(n,m,w);void sortput(int n,int m,int w) /*3.排序输出*/ readfromfile();int c,i,j,k,q=0;int tempN; printf(t*排序输出系统*nn); printf(tt*1.按学校编号输出*n); printf(tt*2.按学校总分输出*n); printf(tt*3.按男团总分输出*n); printf(tt*4.按女团总分输出*n); printf(=nn);do printf(请选择要实现功能的编号(1-

22、4):); scanf(%d,&c);switch(c)case 1: for(i=0;in;i+)tempi=i; for(i=0;in;i+) for(j=i+1;jaj.snum) k=tempi; tempi=tempj; tempj=k; /* 用冒泡排序方法排序*/ for(i=0;in;i+) printf(学校编号:%d 学校总分:%d 男团总分:%d 女团总分:%dn,atempi.snum,atempi.score,atempi.mscore,atempi.wscore); /*按学校编号输出*/ break; case 2: for(i=0;in;i+)tempi=i;

23、for(i=0;in;i+) for(j=i+1;jn;j+)if(atempi.scoreaj.score) k=tempi;tempi=tempj;tempj=k; /* 用冒泡排序方法排序*/for(i=0;in;i+)printf(学校编号:%d 学校总分:%d 男团总分:%d 女团总分:%dn,atempi.snum,atempi.score,atempi.mscore,atempi.wscore); /*按学校总分输出*/break;case 3: for(i=0;in;i+)tempi=i;for(i=0;in;i+) for(j=i+1;jn;j+)if(atempi.msco

24、reaj.mscore) k=tempi;tempi=tempj;tempj=k; /* 用冒泡排序方法排序*/for(i=0;in;i+)printf(学校编号:%d 学校总分:%d 男团总分:%d 女团总分:%dn,atempi.snum,atempi.score,atempi.mscore,atempi.wscore); /*按男团总分输出*/break; case 4: for(i=0;in;i+)tempi=i;for(i=0;in;i+) for(j=i+1;jn;j+)if(atempi.wscoreaj.wscore) k=tempi;tempi=tempj;tempj=k;

25、/* 用冒泡排序方法排序*/for(i=0;in;i+)printf(学校编号:%d 学校总分:%d 男团总分:%d 女团总分:%dn,atempi.snum,atempi.score,atempi.mscore,atempi.wscore); /*按女团总分输出*/break; default: printf(输入错误,请重试!n);printf(请选择 1 返回主菜单 0继续); /*返回菜单或继续排序*/scanf(%d,&q);printf(n);while(q=0);printf(n);if(q!=0)menu(n,m,w);void search(int n,int m,int w

26、) /*查询函数*/ readfromfile();int c,i,j,k,d,l,q=0; printf(t*查询系统*nn); printf(tt*1.按学校编号查询*n); printf(tt*2.按项目编号查询*n); printf(=nn);do k=-1;d=-1;l=-1;printf(请选择要实现功能的编号(1-2):); scanf(%d,&c);switch(c)case 1: printf(要查询的学校编号:); /*查找学校编号下标*/scanf(%d,&c);for(i=0;in;i+)if(ai.snum=c)k=i;if(k=-1)printf(错误:这个学校没有

27、参加此次运动会!n);elseprintf(要查询的项目编号:); /*查找项目编号下标*/ scanf(%d,&c);for(j=0;jm+w;j+)if(ak.tj.inum=c)d=j;if(d=-1)printf(此次运动会没有这个项目n);else /*显示结果*/ printf(这个项目取前 %d名,该学校的成绩如下:n, ak.td.top);for(i=0;i5;i+)if(ak.td.rangei!=0)printf(名次:%dn,ak.td.rangei); break; case 2:printf(要查询的项目编号:); /*查找项目编号下标*/scanf(%d,&c);

28、for(i=0;in;i+)for(j=0;jm+w;j+)if(ai.tj.inum=c)l=j;if(l=-1)printf(此次运动会没有这个项目n);else /*显示结果*/printf(该项目取前 %d名,取得名次的学校n,a0.tl.top);for(i=0; in;i+)for(j=0;j5;j+)if(ai.tl.rangej!=0) printf(学校编号:%d,名次:%dn,ai.snum,ai.tl.rangej); break;default: printf(输入错误,请重试!n);printf(请选择:1.返回主菜单 0.继续); /*返回菜单或继续查询*/scanf(%d,&q);printf(n);while(q=0);printf(n); if(q!=0)menu(n,m,w);void main() /*主函数*/ int n,m,w; printf(ttt欢迎使用ttttnn); printf(t*运动会分数统计系统*nn);printf(请先输入运动会主要信息n); /*设计运动会主要数据个数*/ printf(输入学校个数:); scanf(%d,&n);printf(输入男子项目个数:); scanf(%d,&m);printf(输入女子项目个数:); scanf(%d,&w);menu(n,m,w);- 29 -

移动网页_全站_页脚广告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 

客服