- 1、本文档共27页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《数据结构》
课程设计
专 业:
班 级:
姓 名:
指导教师:
2011年 6 月 28 日
目 录
TOC \t 二级标题-雅黑,2,小标题-雅黑,3,一级标题-雅黑,1 \h HYPERLINK \l _Toc32288 题目 1
HYPERLINK \l _Toc24867 时间 1
HYPERLINK \l _Toc17523 分析 1
HYPERLINK \l _Toc29229 程序要求 2
HYPERLINK \l _Toc11250 数据结构设计 2
HYPERLINK \l _Toc6136 1.概述 2
HYPERLINK \l _Toc29103 2.关键算法 3
HYPERLINK \l _Toc23473 3.查询操作 4
HYPERLINK \l _Toc6746 详细代码 6
HYPERLINK \l _Toc6002 测试结果 18
HYPERLINK \l _Toc16433 1.主菜单窗口 18
HYPERLINK \l _Toc24562 3. 统计各学校总分 19
HYPERLINK \l _Toc2216 4. 按学校编号排序输出 20
HYPERLINK \l _Toc13512 5. 按学校总分排序输出 20
HYPERLINK \l _Toc17167 6. 按男团体总分排序输出 21
HYPERLINK \l _Toc4081 7. 按女团体总分排序输出 21
HYPERLINK \l _Toc29461 8. 按学校编号查询学校某个项目情况 22
HYPERLINK \l _Toc6525 9. 按项目编号查询取得名次的学校 22
HYPERLINK \l _Toc28475 测试非法数据 22
HYPERLINK \l _Toc10704 课程设计总结 26 PAGEREF _Toc10704 。
运动会分数统计
任务:
参加运动会有n个学校,学校编号为1……n。比赛分成m个男子项目,和w个女子项目。项目编号为男子1……m,女子m+1……m+w。不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些取前五名或前三名由学生自己设定。(m=20,n=20,)
功能要求:
1) 可以输入各个项目的前三名或前五名的成绩;
2) 能统计各学校总分,
3) 可以按学校编号或名称、学校总分、男女团体总分排序输出;
4) 可以按学校编号查询学校某个项目的情况;可以按项目编号查询取得前三或前五名的学校。
5) 数据存入文件并能随时查询
6) 规定:输入数据形式和范围:可以输入学校的名称,运动项目的名称
输出形式:
有中文提示,各学校分数为整形;
界面要求:
有合理的提示,每个功能可以设立菜单,根据提示,可以完成相关的功能要求;
存储结构:
学生自己根据系统功能要求自己设计,但是要求运动会的相关数据要存储在数据文件中。(数据文件的数据读写方法等相关内容在c语言程序设计的书上,请自学解决)请在最后的上交资料中指明你用到的存储结构;
测试数据:
要求使用1、全部合法数据;2、整体非法数据;3、局部非法数据。进行程序测试,以保证程序的稳定。测试数据及测试结果请在上交的资料中写明;
时间:2011年6月22日—2011年6月28日星期二
需求分析
程序功能:系统主要用于运动会分数统计方案;
输入方式:键盘输入整形数据
输出方式:屏幕显示
用户界面:中文菜单提示操作
存储方式:存储结构为链表
设计概要
本程序中学校的存储结构为链表:
P
Prev school1 next
头结点
Prev school(最后) next
…………
……
school类为:
class school:public athlete /*学校*/
{
……
public:
int count; /*学校获奖数*/
int serial; /*学校编号*/
int menscore; /*男选手总分*/
int womenscore; /*女选手总分*/
int totalscore; /*总分*/
athlete ath[MaxSize]; /*获奖运动员信息数组,包括分数,名次,项目*/
school *prev;//前指针
school *next; //后指针
};
部分主要的函数:
添加操作add(school* head)
查询操作checkFunc(school *head,int n)
文档评论(0)