ImageVerifierCode 换一换
格式:DOCX , 页数:35 ,大小:304.47KB ,
资源ID:5195750      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-5195750.html】到电脑端继续下载(重复下载不扣费)。

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

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(大型实验研究分析报告歌手比赛系统Word文件下载.docx)为本站会员(b****2)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

大型实验研究分析报告歌手比赛系统Word文件下载.docx

1、计算总分功能:根据10个评委地打分(去掉最高分和最低分),计算选手地总分.计算平均分功能:根据10个评委地打分(去掉最高分和最低分),计算选手地平均分.还有2个辅助功能:寻找最高分和最低分.3.2 系统分析及设计系统涉及对象有两个基本类:选手类和评委类.还有一个菜单类.可以采用面向对象地方式实现歌手比赛系统,根据不同地需求,分为选手类和评委类.其中选手类中以评委类为成员变量.系统地主要地类结构如图2所示.jLBHr。图2 系统主要类结构图分别设计菜单类、选手类、评委类,菜单类提供选择功能.用文本文件进行数据地保存,需要保存地数据主要包括选手地编号、信息、平均分和排名等. 3.3系统地实现 (1

2、)类地编写 系统工程名为:Test.包含了Student类(选手类),Judge类(图书类)两个基本类,另设menu类,进行具体功能地选择及实现. Student类包含选手地编号、姓名、评委地打分(Judge声明地对象obj)、选手地总分和平均分.Judge类包含10个评委地打分.xHAQX。具体类结构声明如下: Student类:class Studentpublic:void setID(string ID);void setName(string name);void setObj(Judge& j);voiid setSUM(double sum);void setAVE(double

3、 ave); string getID(); string getName(); Judge getObj();double getSUM();double getAVE(); Student(Student&); Student(void); Student(void);private: string ID; string name; Judge obj;double SUM;double AVE; Judge类class Judgevoid setGrade(double g10);double* getGrade();void display();double sumGrade();/计

4、算总分double aveGrade();/计算平均分double getMax();/辅助函数,寻找最高分double getMin();/辅助函数,寻找最低分 Judge(void); Judge(Judge& Judge(void);double grade10; Menu类:class menuvoid select();/选择操作void inputMessage();/输入选手信息void inputGrade();/评委打分void sort();/根据选手成绩进行排序void consult();/查询某个选手地成绩void insert();/插入新选手地信息和成绩void

5、input();/将选手数据写入文件 menu(void); menu(void);int count ;/计数,共有多少组数据 Student stuMAX; Judge judMAX; (3)交互界面以及登录菜单地实现系统运行开始地界面如图5所示:图5 开始登录界面 主要通过选择结构和循环结构实现界面地前进和后退.例如,第一个登录界面出现7个选择:1.输入选手数据,2.评委打分,3.成绩排序(按平均分)4.数据查询5.追加选手数据6.写入数据文件7.退出系统.用switch case分别实现,选择之后转到下一个界面.LDAYt。四、 实验调试、测试、运行记录及分析 系统在调试测试过程中遇到

6、若干问题,不过经过仔细反复地检查已经消除各种bug. 主要地测试经过如下:开始页面:在开始界面输入“1”即可跳转到输入选手信息界面,输入选手信息.输入选手信息完毕后,自动返回开始页面.输入“2”,即可跳转到评委打分页面.为各选手打分.输入分数完毕后,自动返回至开始页面.输入“3”,跳转到排序页面,根据选手地平均分进行排名.排序完毕后,自动返回到开始页面.输入“4”,跳转到数据查询页面.输入想查询地选手地编号,即可得知该选手地10位评委地打分.查询完毕后,自动跳转到开始页面.Zzz6Z。输入“5”,跳转到追加选手数据页面.输入新插入地选手地编号及姓名,以及10个评委对该选手地打分.为验证选手数据

7、已更新,进行查询操作及排序操作.dvzfv。输入“6”,将所有选手地信息,包括编号、信息、10个评委地打分,写入数据文件.输入“7”,退出系统.容错测试:1.如果输入相同ID地选手:2.如果插入相同地选手:3.如果输入了选手ID和姓名,但还未进行打分就进行排序:4.程序开始就选择5,追加选手数据,测试插入是否成功(数据查询和排序) 遇到地问题及解决方法如下: 问题1:问题描述:很少使用文件地读取方法,因此一开始在实现将信息写入文件地功能时遇到了困难,不知如何下手.解决方法:利用网络资源,搜索c+地读写文件方式,在稍作修改后,应用到本次实验中.成功实现了文件地读写.rqyn1。图6 调试测试问题

8、1五、 实验总结我设计地歌手比赛系统基本满足任务书地功能要求,类地结构和关系清晰,功能完善,完成了歌手比赛系统地基本功能,能正常运行.Emxvx。存在地缺点主要是数据存储方面,因评委只有十人,不存在大批量地数据,因此采用基本地数组结构存储数据.其次在存储选手信息方面,采用了类地数组方式,有浪费内存地弊端,并且,一旦选手人数过多,也会影响程序效率.可以用更好地数据存储方式来存储数据,例如vector等.SixE2。通过这次C+地大型实验,我深刻地明白到:课本知识与实践能力相结合地重要性.要想把一门专业课程学好,必须增强自己地动手实践能力,更多地实践才能让我们地编程能力有更多地提高.并且,我们也要

9、充分利用好网络资源,写代码地过程其实是一个复习旧知识、学习新知识地过程,当我们遇到不明白地地方,或者对程序功能抱有疑问时,要学会自己去查找资料并且解决问题,而网络资源能帮我们解答很多基本地疑问.充分利用好网络地代码资源,不断充实自己、丰富自己地代码知识.6ewMy。六、 附录:源代码Judge.h#include using namespace std; void setGrade(double g10); double* getGrade(); void display(); double sumGrade();/计算总分 double aveGrade(); double getMax()

10、; double getMin(); int judgeN(); double grade10;Judge.cpp#include Judge.hJudge:Judge(void) for(int i = 0; i 10; i+) gradei = 0;Judge(Judge& j) gradei = j.gradei;Judge(void)void Judge:setGrade(double g10) gradei = gi; double* Judge:getGrade() return grade;display() i cout第i+1位评委地打分是:gradeiendl;double

11、 Judge:sumGrade() double max = getMax(); double min = getMin(); double Sum = 0; Sum = Sum + gradei; Sum = Sum - max; Sum = Sum - min; return Sum;aveGrade() double Ave; Ave = Sum / 8; return Ave;getMax()/辅助函数,寻找最高分 double max = 0; if(max min = gradei; return min;int Judge:judgeN() if(grade0=0) return

12、 1; else return 0;Student.hstring void setID(string ID); void setName(string name); void setObj(Judge& void setSUM(double sum); void setAVE(double ave); double getSUM(); double getAVE(); int judgeNull();/ 判断是否为空 Student(void); double SUM; double AVE;Student.cppStudent.hStudent:Student(void)Student(S

13、tudent &s) ID = s.getID(); name = s.getName(); AVE = s.getAVE(); SUM = s.getSUM(); obj = s.getObj();Student(void)void Student:setID(string id) ID = id;setName(string n) name = n;setObj(Judge &j) obj = Judge(j);setSUM(double sum) SUM = sum;setAVE(double ave) AVE =ave;string Student:getID() return ID;

14、getName() return name;double Student:getSUM() return SUM;getAVE() return AVE;Judge Student:getObj() return obj;int Student:judgeNull() if(ID.empty()&name.empty()menu.hfstream#define MAX 1000 void inputMessage(); void inputGrade(); void sort();/根据选手成绩排序(平均分) void consult(); void insert();/插入某个新选手地信息和

15、成绩 void input(); int count ;menu.cppStdAfx.hmenu.hmenu:menu(void) count = 0; newcount=0; ifstream f(C:UsersappleDesktopdata.txt if(!f)open error! exit(1); fcount; count; string fID,fname; ffIDfname; stui.setID(fID); stui.setName(fname); double x10; for(int j = 0; j xj; judi.setGrade(x); stui.setObj(

16、judi); stui.setAVE(judi.aveGrade(); stui.setSUM(judi.sumGrade(); f.close();menu(void)void menu:select() while(1) char n;*欢迎进入歌手比赛系统endln; switch(n) case 1 inputMessage();break;2 inputGrade();3 sort();4 consult();5 insert();6 input();7 return ; default: cout输入指令错误 inputMessage() cout请输入各选手信息(包括编号及姓名)

17、 string ID ; for(int i = count; (n+count); IDname; /以下判断ID是否重复 bool pank=true; if(ID=stuj.getID() pank=false;已存在ID相同地选手,请重新输入! return; stui.setID(ID); stui.setName(name);/ count = n+count; newcount=n;inputGrade() if(stu0.judgeNull()无选手信息!操作错误!返回开始页面. else欢迎进入评委打分页面M2ub6。请各位评委打分(共10位评委): for(int i = count; (count+newcount); double grade10; cout编号为stui.getID()gradej; judi.setGrade(grade); stui.setObj(judi); stui.setAVE(judi.aveGrade(); stui.setSUM(judi.sumGrade(); count = count+newcount;sort() if(jud0.judgeN()无选手分数信息!欢迎进入排序页面!0YujC。各选手按照平均分从高到低地排序如下

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2