数据结构运动会分数统计课程设计

合集下载

运动会分数统计(数据结构课程设计)python

运动会分数统计(数据结构课程设计)python

运动会是学校中一项重要的活动,通过运动会可以增强学生的体质,增进师生之间的情感,同时也能够激发学生的运动热情和团队精神。

而对于运动会的分数统计来说,如何高效、准确地完成这项工作是非常重要的。

本文主要介绍了基于数据结构课程设计的运动会分数统计系统,使用Python语言实现。

二、系统设计1. 数据结构的选择在设计运动会分数统计系统时,需要考虑如何存储和管理参赛队伍和成绩信息。

由于参赛队伍和成绩信息的数量较大,因此需要选择适合高效查询和排序的数据结构。

本系统选择使用Python中的字典(dictionary)和列表(list)来存储和管理数据。

2. 数据的存储在系统中,每支队伍的信息包括队伍编号、队伍名称和各项比赛成绩等。

这些信息可以使用字典来存储,其中队伍编号作为键,队伍信息作为值。

而各项比赛成绩可以使用列表来存储,方便进行排序和统计。

3. 数据的输入为了方便输入参赛队伍和成绩信息,本系统提供了相应的输入界面,用户可以通过界面逐一输入每支队伍的信息。

程序也提供了批量导入功能,用户可以通过导入文件的方式一次性输入所有的参赛队伍和成4. 数据的统计和输出系统可以对输入的成绩信息进行统计和排序,可以按照总分或特定比赛项目的成绩进行排序,并将排名信息输出到文件中。

排名信息包括队伍名称、总分和各项比赛成绩,方便后续的奖励和表彰工作。

三、系统实现1. 数据结构类的设计为了方便对队伍和成绩信息进行管理,本系统设计了队伍(Team)和成绩(Score)两个类,分别用于存储队伍信息和比赛成绩。

2. 主程序的设计系统的主程序主要包括数据的输入、统计和输出三个功能。

用户可以通过交互式界面输入队伍和成绩信息,也可以通过命令行参数进行批量导入。

系统会对输入的成绩信息进行统计和排序,并将排名信息输出到指定的文件中。

3. 界面设计为了方便用户操作,系统提供了简洁清晰的交互式界面。

用户可以通过界面进行数据的输入和操作,也可以查看和导出排名信息。

数据结构课程设计运动会分数统计

数据结构课程设计运动会分数统计

数据结构课程设计报告(一)课题一运动会分数统计1. 任务参加运动会有n个学校,学校编号为1……n。

比赛分成m个男子项目,和w 个女子项目。

项目编号为男子1~m,女子m+1~m+w。

不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些项目取前五名或前三名由学生自己设定。

(m<=20,n<=20)2. 功能要求1) 可以输入各个项目的前三名或前五名的成绩;2) 能统计各学校总分;3) 可以按学校编号、学校总分、男女团体总分排序输出;4) 可以按学校编号查询学校某个项目的情况;5) 可以按项目编号查询取得前三或前五名的学校。

3.需求分析在程序中,用户输入各运动会项目的排名情况,程序会计算出各校的得分情况存储于顺序表中,可供查询。

4.概要设计struct{int order[5]; //项目排名}sub[10];struct{int score; //学校总分int score1; //学校男团总分int score2; //学校女团总分}sch[5];程序调用关系如下:主程序模块成绩输入模块总分输出模块排名查询模块学校情况查询模块项目情况查询模块5.详细设计#include <windows.h>#include<stdio.h>#include<stdlib.h>char SCHOOL[5][13]={"东华大学","上海交大","复旦大学","同济大学","华东师范大学"};char SUBJECT[10][10]={"男子100米","男子200米","男子400米","男子跳高 ","男子跳远","女子跳高","女子跳远","女子铅球", "女子100","女子400米"};int SCORE[2][5]={{7,5,3,2,1},{5,3,2}};struct //存储项目信息{int order[5]; //排名}sub[10];struct //存储学校信息{int score; //学校总分int score1; //学校男团总分int score2; //学校女团总分}sch[5];int menu();void func1(); //输入成绩void calculate(); //计算各校成绩void func2(); //输出各校总分int menu2();void func31(); //按学校编号输出各项成绩void func32(); //排序输出各校总分void func33(); //排序输出各校男团总分void func34(); //排序输出各校女团总分void func4(); //输出学校情况void func5(); //输出项目情况int main(){menu();}int menu(){int n;printf("_______________________________________________________\n");printf(" MENU \n");printf(" 1.输入成绩 \n"); printf(" 2.各校总分 \n");printf(" 3.成绩排序 \n");printf(" 4.学校情况 \n");printf(" 5.项目情况 \n");printf(" 6.退出系统 \n\n");printf(" 请输入编号:");scanf("%d",&n);system("cls");switch(n){case 1:func1();calculate();break;case 2:func2();break;case 3:menu2();break;case 4:func4();break;case 5:func5();break;case 6:return 0;default:menu();}menu();}void func1(){int i;printf("_______________________________________________________\n"); printf(" 请输入各体育项目名次所对学校编号 \n"); printf(" 学校编号(1:东华大学,2:上海交大,3:复旦大学,4:同济大学,5:华东师范大学,0:退出) \n");for(i=0;i<10;i++){printf(" %d.%s 第一名:",i+1,SUBJECT[i]);scanf("%d",&sub[i].order[0]);if(sub[i].order[0]==0)menu();printf("\n 第二名:");scanf("%d",&sub[i].order[1]);if(sub[i].order[1]==0)menu();printf("\n 第三名:");scanf("%d",&sub[i].order[2]);if(sub[i].order[2]==0)menu();if(i%2==0){printf("\n 第四名:");scanf("%d",&sub[i].order[3]);if(sub[i].order[3]==0)menu();printf("\n 第五名:");scanf("%d",&sub[i].order[4]);if(sub[i].order[4]==0)menu();}}system("cls");}void calculate(){int i,j,k;for(i=0;i<5;i++){for(j=0;j<5;j++) //求出各校男团总分{if(j%2==0){for(k=0;k<5;k++){if(sub[j].order[k]==i+1)sch[i].score1=sch[i].score1+SCORE[0][k];}}else{for(k=0;k<3;k++){if(sub[j].order[k]==i+1)sch[i].score1=sch[i].score1+SCORE[1][k];}}}for(;j<10;j++) //求出各校女团总分{if(j%2==0){for(k=0;k<5;k++){if(sub[j].order[k]==i+1)sch[i].score2=sch[i].score2+SCORE[0][k];}}else{for(k=0;k<3;k++){if(sub[j].order[k]==i+1)sch[i].score2=sch[i].score2+SCORE[1][k];}}}sch[i].score=sch[i].score1+sch[i].score2; //求出各校总分}}void func2(){int i;printf("_______________________________________________________\n"); printf(" 各校总分 \n");for(i=0;i<5;i++)printf(" %d.%s %d分\n",i+1,SCHOOL[i],sch[i].score);printf("\n\n输入任意值返回");getch();system("cls");}int menu2(){int n;printf("_______________________________________________________\n");printf(" 成绩排序 \n");printf(" 1.按学校编号 \n"); printf(" 2.按学校总分 \n");printf(" 3.按男团总分 \n");printf(" 4.按女团总分 \n");printf(" 5.返回 \n\n");printf(" 请输入编号:");scanf("%d",&n);system("cls");switch(n){case 1:func31();break;case 2:func32();break;case 3:func33();break;case 4:func34();break;case 5:menu();default:menu2();}return 0;}void func31(){int i;printf("_______________________________________________________\n");printf(" 按学校编号排序 \n");for(i=0;i<5;i++){printf(" %d.%s 学校总分 %d分\n",i+1,SCHOOL[i],sch[i].score);printf(" 男团总分 %d分\n",sch[i].score1);printf(" 女团总分 %d分\n",sch[i].score2);}printf("\n\n输入任意值返回");getch();system("cls");}void func32(){int a[5][2],i,j,p,q,k;printf("_______________________________________________________\n"); printf(" 按学校总分排序 \n"); for(p=0;p<5;p++){a[p][0]=p;a[p][1]=sch[p].score;}for(i=0;i<4;i++) //将各校总分从大到小排序for(j=0;j<4;j++)if(a[i][1]<a[i+1][1]){q=a[i][1];a[i][1]=a[i+1][1];a[i+1][1]=q;k=a[i][0];a[i][0]=a[i+1][0];a[i+1][0]=k;}for(p=0;p<5;p++)printf(" %d.%s %d分\n",p+1,SCHOOL[a[p][0]],sch[p].score); printf("\n\n输入任意值返回");getch();system("cls");}void func33(){int a[5][2],i,j,p,q,k;printf("_______________________________________________________\n"); printf(" 按男团总分排序 \n"); for(p=0;p<5;p++) //将各校男团总分从大到小排列{a[p][0]=p;a[p][1]=sch[p].score1;}for(i=0;i<4;i++)for(j=0;j<4;j++)if(a[i][1]<a[i+1][1]){q=a[i][1];a[i][1]=a[i+1][1];a[i+1][1]=q;k=a[i][0];a[i][0]=a[i+1][0];a[i+1][0]=k;}for(p=0;p<5;p++)printf(" %d.%s %d分\n",p+1,SCHOOL[a[p][0]],sch[p].score1); printf("\n\n输入任意值返回");getch();system("cls");}void func34(){int a[5][2],i,j,p,q,k;printf("_______________________________________________________\n"); printf(" 按女团总分排序 \n"); for(p=0;p<5;p++) //将各校女团总分从大到小排列{a[p][0]=p;a[p][1]=sch[p].score2;}for(i=0;i<4;i++)for(j=0;j<4;j++)if(a[i][1]<a[i+1][1]){q=a[i][1];a[i][1]=a[i+1][1];a[i+1][1]=q;k=a[i][0];a[i][0]=a[i+1][0];a[i+1][0]=k;}for(p=0;p<5;p++)printf(" %d.%s %d分\n",p+1,SCHOOL[a[p][0]],sch[p].score2);printf("\n\n输入任意值返回");getch();system("cls");}void func4(){int i,j,a,b=0;printf("_______________________________________________________\n"); printf(" 学校情况 \n"); printf("学校编号(1:东华大学,2:上海交大,3:复旦大学,4:同济大学,5: 华东师范大学,0:退出)\n");printf(" 请输入学校编号:");scanf("%d",&i);if(i==0){system("cls");menu();}else{if(i>5||i<0){system("cls");func4();}else{printf("项目编号(1:男子100米,2:男子200米,3:男子400米,4:男子跳高,5:男子跳远\n");printf(" 6:女子跳高,7:女子跳远,8:女子铅球,9:女100,10:女子400米,0:退出)\n\n");printf("请输入项目编号:");scanf("%d",&j);if(j==0){system("cls");menu();}else if(j>10||j<0){system("cls");func4();}else if(j%2!=0)for(a=0;a<5;a++){if(sub[j-1].order[a]==i){printf("\t\t%s %s 第%d",SCHOOL[i-1],SUBJECT[j-1],a+1);break;}}else{for(a=0;a<3;a++){if(sub[j-1].order[a]==i){printf("\t\t %s %s 第%d"SCHOOL[i-1],SUBJECT[j-1],a+1 );b=1;break;}}if(b==0)printf("\t\t %s %s 未获得名次",SCHOOL [i-1],SUBJECT[j-1]);}}}printf("\n\n输入任意值返回");getch();system("cls");}void func5(){int i,j;printf("_______________________________________________________\n"); printf(" 项目情况 \n"); printf(" 项目编号(1:男子100米,2:男子200米,3:男子400米,4:男子跳高,5:男子跳远\n");printf(" 6:女子跳高,7:女子跳远,8:女子铅球,9:女子100米 ,10:女子400米,0:退出)\n");printf(" 请输入项目编号:");scanf("%d",&i);if(i==0){system("cls");menu();}else if(i>10||i<0){system("cls");func5();}else{if(i%2==0)for(j=0;j<3;j++)printf(" 第%d名: %s\n",j+1,SCHOOL[(sub[i-1].order[j])-1]);else for(j=0;j<5;j++)printf("第%d名: %s\n",j+1,SCHOOL[(sub[i-1].order[j])-1]);}printf("\n\n输入任意值返回");getch();system("cls");}6.调试分析1)在函数calculate中,将sub[j].order[k]==i+1中的i+1错写为i,导致各校成绩的统计出错,后面的功能运作出现问题。

数据结构课程设计--运动会成绩管理系统

数据结构课程设计--运动会成绩管理系统

目录1 需求分析 (1)1.1 问题描述 (1)1.2 基本要求 (1)1.3 测试数据 (1)2 概要设计 (2)2.1 数据结构 (2)2.2 程序模块及之间的调用关系 (2)3 详细设计 (3)3.1 数据类型定义 (3)3.2 函数之间的调用关系 (3)3.3 算法设计 (4)4 测试结果 (5)4.1多组数据输入与输出 (5)5 调试分析 (9)参考文献 (10)附录 (11)1 需求分析1.1 问题描述运动会分数统计系统参加运动会有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 基本要求(1) 可以输入各个项目的前三名或前五名的成绩;(2) 能统计各系总分,(3) 可以按系编号、系总分、男女团体总分排序输出;(4) 可以按系编号查询系某个项目的情况;可以按项目编号查询取得前三或前五名的系。

1.3 测试数据(1) 输入:进入输入界面,根据提示,输入参赛学校个数,再输入:男子组和女子组个数。

再根据提示的选择菜单1:输入各项中的获奖学校。

(2) 输入:2查看输出结果。

(3) 输入:3查看输出结果。

(4) 输入:4查看输出结果。

(5) 输入:5查看输出结果。

(6) 输入:6查看输出结果。

(7) 输入:7根据提示输入系编号和项目编号。

(8) 输入:8根据提示输入系编号和项目编号。

(8) 输入:9,退出。

2.1 数据结构(1) 学校:代号,男子团体个数和总分,女子团体个数和总分。

(2) 运动项目:项目编号,男子项目,女子项目,前三名,前五名,第一名系的编号,第二名系的编号,第三名系的编号,第四名系的编号,第五名系的编号。

2.2 程序模块及之间的调用关系3.1算法设计主要算法的设计思想:本程序主要是使用数组来实现操作。

数据结构课程设计-运动会分数统计系统

数据结构课程设计-运动会分数统计系统

运动会分数统计系统Ø 设计内容1. 任务:参加运动会有n个学校,学校编号为1~n。

比赛分成m个男子项目,和w个女子项目。

项目编号为1~m,女子为m+1~w。

不同的项目取前5名或前3明积分;取前5名的积分为:7、5、3、2、1,前3名的积分分别为:5、3、2;哪些项目取前5名或前3名由学生自己决定。

(m<=20,n<=20)。

2. 功能要求:1) 可以输入各个项目的前3名或前5名的成绩;名的成绩;2) 能统计各个学校总分;能统计各个学校总分;3) 可以按学校编号、学校总分、男女团体总分排序输出;可以按学校编号、学校总分、男女团体总分排序输出;4) 可以按学校编号查询学校某个项目的情况;可以按学校编号查询学校某个项目的情况;5) 可以按项目编号查询取得前3或前5名的学校。

名的学校。

Ø 设计思路1. 系统结构设计图运动会SportsMeeting东华University交大University……比赛项目集合SportEvents 项目1 Event项目2 Event…………复旦University运动会分数统计系统结构设计图2. 思路分析1) 从上面的结构设计图来看,隐含地给出了第一个约束条件:每个参赛学校均参加所有的比赛项目。

然而这种设计思路并不符合实际情况,因为每个学校有权利选择参加或不参加某个比赛项目。

加某个比赛项目。

2) 首先,在上述结构图中,比赛项目Event 是最小的数据存储基本单元。

比赛项目集合SportEvents 可以理解为Event 数组,包含了所有的比赛项目。

根据约束,只要有学校University 参加运动会,此学校就包含了一个SportEvents 集合,即为每个学校分配自己的项目成绩单。

有n 个学校报名参加了运动会SportsMee ng ,大会的工作人员根据比赛项目结果统计各个学校的成绩。

赛项目结果统计各个学校的成绩。

因此,因此,这种设计结构有3层包含关系,层包含关系,但是每一部分但是每一部分相互独立,耦合性弱。

运动会分数统计系统数据结构 课程设计 附代码

运动会分数统计系统数据结构 课程设计 附代码

摘要21世纪是个信息化的时代,现代计算机技术的发展,为各行各业的发展创造了一个全新的时代背景——人们的生活、工作等已经越来越离不开计算机科学的运用,体育作为个人、家庭、社会的一个主要实践领域,大大小小的运动会也在各大中院校中展开,自从计算机科学涉及运动领域后,人们对运动会的管理也从人工的向自动化转变。

运用数据结构的知识解决运动会分数统计的问题,编写一个程序来完成运动会分数统计系统.本程序设计中,可以输入参加运动会的学校编号及项目编号;根据具体情况选择输入参加项目的男女类别和取成绩名次类别;最后选择输入名次;实现数据统计,排序输出,学院及项目查询等功能。

关键词:运动会分数统计程序排序查询目录1 设计内容和要求 (1)1.1具体内容及要求 (1)2.总体设计 (3)2.1系统设计方案 (3)2.2功能模块设计 (3)3.详细设计 (5)3.1数据结构定义 (5)3.2比赛数据输入模块 (6)3.3比赛成绩输出模块 (7)3.3查询比赛成绩模块 (8)4.调试与测试 (10)4.1测试数据 (10)4.1.1 School.txt (10)4.1.2 MatchItem.txt (11)4.1.3 PreNews.txt (12)4.1程序主界面 (12)4.2输入数据 (12)4.3排序输出学校总分 (14)4.4排序输出男子团体总分 (14)4.5排序输出女子团体总分 (15)4.6按学校查询项目数据 (15)4.7按项目查询数据 (16)5.总结 (17)参考文献 (18)致谢..................................................... 错误!未定义书签。

1 设计内容和要求数据结构课程设计是为数据结构课程独立开设的实践性教学环节。

数据结构课程设计对于巩固数据结构知识,加强学生的实际动手能力和提高学生综合素质是十分必要的。

课程设计的目的是要求学生达到熟练掌握C语言的基本知识和技能;了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;提高程序设计和调试能力。

数据结构实验——运动会分数统计

数据结构实验——运动会分数统计

数据结构实验——运动会分数统计数据结构实验——运动会分数统计1.简介本实验旨在设计一个分数统计系统,用于记录和分析运动会比赛的分数。

2.系统需求2.1 功能需求2.1.1 输入运动员信息:包括姓名、年龄、性别等。

2.1.2 输入比赛项目信息:包括项目名称、项目时间、参赛人数等。

2.1.3 输入运动员的比赛成绩:包括项目名称、运动员姓名、成绩等。

2.1.4 统计比赛成绩:根据输入的成绩,计算每个比赛项目的平均成绩、最高成绩、最低成绩等。

2.1.5 查询运动员成绩:根据运动员姓名或项目名称,查询其成绩。

2.1.6 输出成绩报表:将比赛的成绩信息以报表的形式输出。

2.2 性能需求2.2.1 响应时间:系统对用户的请求要求及时响应,保证用户操作的流畅性。

2.2.2 稳定性:系统需要稳定运行,不易崩溃或出现错误。

2.2.3 可扩展性:系统需要支持添加新的运动员信息和比赛项目,能够适应不同规模和类型的运动会。

3.系统设计3.1 数据结构设计3.1.1 运动员信息结构:包括姓名、年龄、性别等属性。

3.1.2 比赛项目信息结构:包括项目名称、项目时间、参赛人数等属性。

3.1.3 成绩信息结构:包括项目名称、运动员姓名、成绩等属性。

3.2 系统模块设计3.2.1 运动员管理模块:负责录入和查询运动员信息。

3.2.2 项目管理模块:负责录入和查询比赛项目信息。

3.2.3 成绩管理模块:负责录入和统计比赛成绩。

3.2.4 报表输出模块:负责将比赛成绩以报表的形式输出。

4.系统实现4.1 编程语言:选择合适的编程语言进行开发。

4.2 开发环境:搭建适合的开发环境,包括编译器、集成开发环境(IDE)等。

4.3 数据库设计:设计合适的数据库结构,用于存储运动员信息、比赛项目信息和成绩信息。

4.4 界面设计:设计友好的用户界面,方便用户进行操作。

4.5 测试和调试:对系统进行全面的测试和调试,以保证系统的稳定性和正确性。

5.法律名词及注释5.1 隐私政策:指用户个人信息的保护政策,保证用户信息的安全和私密性。

数据结构运动会分数统计课程设计

数据结构运动会分数统计课程设计

《数据结构》课程设计目录1.需求分析------------------------------------------------------21.1问题描述-----------------------------------------------------------21.2基本任务-----------------------------------------------------------22.概要设计------------------------------------------------------22.1主界面设计---------------------------------------------------------22.2数据结构设计-------------------------------------------------------32.3系统功能设计-------------------------------------------------------33.模块设计------------------------------------------------------33.1模块设计-----------------------------------------------------------33.2系统子模块及功能设计-----------------------------------------------43.3系统模块之间的调用关系---------------------------------------------44.详要设计------------------------------------------------------54.1数据结构设计-------------------------------------------------------54.2系统主要模块设计---------------------------------------------------65.调试分析------------------------------------------------------85.1创建学校链表-------------------------------------------------------85.2添加获奖学生-------------------------------------------------------85.3按项目查学校成绩---------------------------------------------------115.4按学校编号查参加项目-----------------------------------------------146.用户使用说明--------------------------------------------------157.参考文献------------------------------------------------------158.对软件自我评价------------------------------------------------159.程序设计源代码------------------------------------------------1610.心得体会-----------------------------------------------------22一.需求分析1.1 问题描述1.课程设计题目:运动会分数统计。

课程设计运动会分数统计

课程设计运动会分数统计

课程设计运动会分数统计数据结构课程设计课程名称数据结构课程设计专业计算机科学与技术(网络工程)班级学生姓名学号设计题目运动会分数统计指导教师设计起止时间: . 6.18- .6.29数据结构课程设计任务书学院计算机科学与技术(网络工程)专业课程设计题目运动会分数统计学生姓名学号班级起止日期 -06-18至 -06-29指导教师发任务书日期 6月 10日一.课程设计题目:运动会分数统计二.设计要求:本课程设计要求学生一人一题,个人独立完成。

设计中使用到以下知识点:(1)线性结构基本算法实现(2)图形结构基本算法实现(3)查找基本算法实现该课程设计提交的文档包括以下内容:(1)问题描述(2)基本要求(3)算法思想(4)模块划分:包括一些必要的流程图.(5)数据结构(6)源程序(7)测试例子及结果分析(8)心得体会三.设计内容和步骤:(1)任务:参加运动会有n个学校,学校编号为1……n。

比赛分成m个男子项目,和w个女子项目。

项目编号为男子1……m,女子m+1……m+w。

不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些取前五名或前三名由学生自己设定。

(m<=20,n<=20),按要求实现相应的数据输入、查询、计分等功能。

(2)基本要求:1) 能够输入各个项目的前三名或前五名的成绩;2) 能统计各学校总分;3) 能够按学校编号、学校总分、男女团体总分排序输出;4) 能够按学校编号查询学校某个项目的情况;5) 能够按项目编号查询取得前三或前五名的学校。

(3)测试数据1)首先进入成绩录入界面,先输入学校编号1,再输入学校1各个项目成绩0或1(‘0’表示没获得该项目的该名次,‘1’表示获得了该项目的该名次);然后再输入第二个学校编号2,再输入成绩;当输入其它的学校编号和成绩会提示错误输入,重新输入。

2)然后进入总目录,输入:1 统计各学校总分并输出;3)输入:2 按学校编号排序输出;4)输入:3 按学校总分排序输出;5)输入:4 按男团体总分排序输出;6)输入: 5 按女团体总分排序输出;7) 输入:6 按学校编号查询学校某个项目情况;8)输入:7 按项目编号查询取得名次的学校;9)输入:0 退出系统;10)输入其它数据会提示错误输入,重新输入。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

《数据结构》课程设计目录1.需求分析------------------------------------------------------21.1问题描述-----------------------------------------------------------21.2基本任务-----------------------------------------------------------22.概要设计------------------------------------------------------22.1主界面设计---------------------------------------------------------22.2数据结构设计-------------------------------------------------------32.3系统功能设计-------------------------------------------------------33.模块设计------------------------------------------------------33.1模块设计-----------------------------------------------------------33.2系统子模块及功能设计-----------------------------------------------43.3系统模块之间的调用关系---------------------------------------------44.详要设计------------------------------------------------------54.1数据结构设计-------------------------------------------------------54.2系统主要模块设计---------------------------------------------------65.调试分析------------------------------------------------------85.1创建学校链表-------------------------------------------------------85.2添加获奖学生-------------------------------------------------------85.3按项目查学校成绩---------------------------------------------------115.4按学校编号查参加项目-----------------------------------------------146.用户使用说明--------------------------------------------------157.参考文献------------------------------------------------------158.对软件自我评价------------------------------------------------159.程序设计源代码------------------------------------------------1610.心得体会-----------------------------------------------------22一.需求分析1.1 问题描述1.课程设计题目:运动会分数统计。

2.任务:加运动会有n个学校,学校编号为1……n。

比赛分成m个男子项目,和w个女子项目。

项目编号为男子1……m,女子m+1……m+w。

不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些取前五名或前三名由学生自己设定。

(m<=20,n<=20)3.问题分析:1)、每个学校有运动员要参加运动项目,故存储结构要有三个,项目结构体,学生信息结构体和学校链表。

每个结点存储一个学校,每个学校可以有多名运动员参加运动项目。

由此,存储结构就建立了。

2)、要求不同的项目根据具体情况取去前五名或前三名积分,则可以设定标准,即当参加某项目的运动员数等于或多于五人时,就取该项目的前五名进行积分,取前五名的积分分别为:7,5,3,2,1。

当参加某一项目的人数少于五人时,则去该项目的前三名进行积分,去取前三名的积分分别为:5,3,2。

3)、要求能统计学校的总分,并可以按学校编号输出每个学校的参赛信息及每个学校每个运动员的信息和所有运动项目清单。

以上这些功能可以通过遍历学校链表来实现。

4)、要求可以学校编号查询学校某个项目的情况,用户输入学校编号和项目编号,通过遍历学校链表即可实现。

5)、要求可以按编号查询取得前三或前五名的学校,用户输入要查询的项目的编号,通过遍历学校链表即可实现。

6)、设置菜单函数menu(),产生用户界面。

规定:输入数据形式和范围:可以输入学校的名称,运动项目的名称输出形式:有中文提示,各学校分数为整形界面要求:有合理的提示,每个功能可以设立菜单,根据提示,可以完成相关的功能要求。

存储结构:学生自己根据系统功能要求自己设计,但是要求运动会的相关数据要存储在数据文件中。

测试数据:要求使用1、全部合法数据;2、整体非法数据;3、局部非法数据。

进行程序测试,以保证程序的稳定。

1.2 基本任务通过用户调查分析及实际需求,系统需要实现如下基本任务:1).输入各个项目的前三名或前五名的成绩;2).统计各学校总分;3).按学校编号或名称、男女团体总分排序输出;4).按学校编号查询学校某个项目的情况;可以按项目编号查询取得前三或前五名的学校。

数据存入文件并能随时查询。

二.概要设计为了完成需求分析的基本任务,主要从以下3个方面进行设计:2.1 主界面设计为了实现运动会分数统计的各项功能,设计了一个含有多个菜单项的主控菜单模块以链接系统的各项功能,以方便用户使用系统。

系统主控菜单运行界面如图1所示:图1 运动会分数统计主菜单2.2 数据结构设计系统采用数据的存储结构定义:运动项目结构体、运动员信息结构体、学校链表此外,还定义了一些全局变量:学校总数SchoolCount、男生项目总数BoyProject、女生项目总数GirlProject、项目总数TotalProject、项目表Project_T[41]。

2.3 系统功能设计⑴.创建学校的链表:void CreatSchoolLink(School &head);⑵.添加获奖学生:void AddStudentLink(School &head);⑶.按项目编号查询取得前三或前五名的学校。

void Find_Project_ID(School &head,int Project_ID);⑷.按学校编号查询学校某个项目。

void Find_School_Project(School &head,int School_ID,int Project_ID);⑸.成绩统计:void ScoreCount(School &head);⑹.输出参赛结果:void OutPut_Link(School head);(7).添加学生数据:void AddStudent(School &head);(8).菜单函数:int menu();(9).主函数:int main();三.模块设计3.1 模块设计系统主要包含主程序模块和其它链表操作模块。

其调用关系如图2所示。

图2 模块调用示意图3.2 系统子模块及其功能设计系统设计了8个子功能模块,8个子功能模块的描述如下:⑴.创建学校的链表:void CreatSchoolLink(School &head);⑵.添加获奖学生:void AddStudentLink(School &head);⑶.按项目编号查询取得前三或前五名的学校。

void Find_Project_ID(School &head,int Project_ID);⑷.按学校编号查询学校某个项目。

void Find_School_Project(School &head,int School_ID,int Project_ID);⑸.成绩统计:void ScoreCount(School &head);⑹.输出参赛结果:void OutPut_Link(School head);(8).添加学生数据:void AddStudent(School &head);(8).菜单函数:int menu();3.3 系统模块之间的调用关系系统的10个子模块之间的主要调用关系如图3所示:图3 系统函数调用关系图四.详细设计4.1 数据结构设计系统采用线性表的链式存储结构存储学校信息。

结点定义如下:typedef struct SchoolNode{int number;//学校编号char name[10];int count;//运动员人数int boyscore;//男子团体总分int girlscore;//女子团体总分int totalscore;//团体总分int jifen;//积分Student students[20];//参赛学生struct SchoolNode *next;}SchoolNode,*School;4.2 系统主要模块设计(1)创建学校链表算法思想及程序代码:void CreatSchoolLink(School &head){//创建学校的链表School p;int i;head=p=(School)malloc(sizeof(SchoolNode));for(i=1;i<=SchoolCount;i++){ p=p->next=(School)malloc(sizeof(SchoolNode));printf("请输入编号为%d的学校的名称:\n",i);scanf("%s",p->name);p->number=i;p->count=0;p->boyscore=0;p->girlscore=0;p->totalscore=0;p->jifen=0;}p->next=NULL;//使指针指向空head=head->next;//头指针后移}(2)添加获奖学生函数程序代码:void AddStudentLink(School &head){//添加获奖学生School L,p;int School_ID; //学校编号char StudentName[20]; //学生姓名int sex;//性别int Project_ID; //项目编号int score; //成绩int ranking; //名次printf("请输入学生的姓名:\n");scanf("%s",StudentName);printf("请输入该学生所在学校的编号:\n");scanf("%d",&School_ID);printf("请输入该学生的性别(0--女,--男):\n");scanf("%d",&sex);printf("请输入该学生参加的项目编号:\n");scanf("%d",&Project_ID);if(sex==0) GirlProject=Project_ID;if(sex==1) BoyProject=Project_ID;printf("请输入该学生该项目的得分:\n");scanf("%d",&score);printf("请输入该学生在该项目中的名次:\n");scanf("%d",&ranking);L=head;while(L){ if(L->number==School_ID){ p=L;p->count=p->count+1; //运动员数+1strcpy(p->students[p->count].name, StudentName); //学生姓名p->students[p->count].Project=Project_ID ;//得分项目Project_T[Project_ID].count=Project_T[Project_ID].count+1; //该项目得分人数+1p->students[p->count].ranking=ranking;//得分名次p->students[p->count].score=score;//得分p->students[p->count].sex=sex; //性别break;}else L=L->next;}}(3)按学校项目查询前三名和前五名学校函数程序代码:void Find_Project_ID(School &head,int Project_ID){ //按项目编号查询取得前三或前五名的学校。

相关文档
最新文档