C语言课程设计报告—歌星大奖赛评分系统
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
C语言课程实习报告课程名称:歌星大奖赛
学院:信息工程学院
专业:通信工程
班级:
学号:
姓名:
指导老师:
第一部分:课程设计编号、名称、内容
名称:歌星大奖赛
内容:
【要求】
(1)在歌星大奖赛中,有十个评委为参赛的选手打分,分数为1~100分。选手最后得分为:去掉一个最高分和一个最低分后其余8个分数的平均植。请编写一个程序实现。
(2)同时对评委评分进行裁判,即在10个评委中找出最公平(即评分最接近平均分)和最不公平(即与平均分的差距最大)的评委。
【提示】
一、需求分析
这个问题的第一个要求算法比较简单,但是要注意在程序中判断最大、最小值的变量是如何赋值的。第二个要求为了考虑效率,要用到排序技术。
第二部分:程序总体设计思路
由于C语言是面对过程的语言,故我的设计思路是根据目标程序运行的过程来编写的。
在编写本程序的过程中,首先我借助购买的指导材料,了解了一些目标程序运行的次序与界面的操作方法,然后按照题目的具体要求进行思考和设计。
具体的设计思路如下:
程序的要求是根据十个评委对歌手的打分情况,求出这个歌手的平均成绩和最公平及最不公平的裁判。首先,我先考虑到程序的数据输入,可以用scanf函数来解决,并将输入的数据存放于数组中。随后对存放在数组中的数据进行排序,这步为执行找出最不公平的裁判提高了效率,只需将排好序的数组的首尾分值与平均值进行比较即可。将排好序的数组中间的八个数求平均值即为此歌手的成绩,可见排序法可大大的简化程序。接下来是最后一个任务就是找最公平的裁判,此过程我使用拆半法,先将靠近中间的一个裁判假设为最公平的,再将他前面的裁判与之比较,找出前半部分的最公平的裁判,再将之与后半部分的进行比较,得出最终的最公平的裁判。为了方便管理员更好的使用界面操作,我还设置了每输入完一组数据并得到结果后,或接着输入下组数据或按0跳出界面。
整个程序的设计思路到此结束。
第三部分:程序功能划分、图示及流程图
【功能模块划分及其流程图】
本程序功能模块根据程序设计的需求,综合程序的实用性、人性化、智能化的考虑,将程序划分为6个部分分别编写,程序主体功能将由这6个部分来完成。这6个部分依次是:
1.分数的输入部分;
2.对分数进行的排序部分;
3.计算平均值的部分;
4.找出最不公平裁判部分;
5.找出最公平裁判部分;
6.数据的输出部分
总体设计:
系统功能模块图
程序流程
系统的执行应从功能菜单的选择开始,依据用户的选择来进行后续的处理,直到用户选择退出系统为止,其间应对用户的选择做出判断及异常处理。系统的流程图如下:
是
第四部分:程序设计数据、运行结果
本程序是一款应用软件,故数据设计、程序运行结果应在程序的运用中得以体现,现在通过一个程序的运用事例来对数据设计、程序运行结果进行演示与实现:
【软件运用举例】
程序开始界面如下:
管理员输入评委对任意歌手的打分,输入完毕后程序如下菜单界面:
管理员输入评委对任意歌手的打分,当输入有误后程序如下菜单界面:
此程序显示了裁判对歌手的平均分数,以及根据裁判们打分与平均分数间的差距判断出的最公平和最不公平裁判的位置及打分!
当出现最高分的裁判和最低分的裁判各不止一个时,输入数据后程序界面的运行如下:
第五部分:程序改进思路
【针对第一点:程序算法精简问题】
>>改进思路:
1. 算法上除了采用结构体数组外,考虑在程序的算法设计上引入排序法,考察这样对数据组织运算效率上是具有提高作用的。
2. 就现有知识水平、经验来看,对我来说,本程序的算法设计上已经是最精简的了。C语言知识博大精深,有必要对C语言的专着进行研究学习,多阅读别人的程序代码、多动手实践操作与设计,这样便对程序算法精简改进提供了可能。
【针对第二点:用户输入错误问题】
>>改进思路:
对每个数据输入段代码进行更深的研究与分析,明确变量的类型、可能的数值,然后进行分类判断(if或switch语句),必要时借助for循环语句来控制程序进行,保障各模块运行相对独立,稳定准确执行各自功能。典型方法是如果输入数据错误,通过printf输出问题,并用for 或(do)while构成循环,直到用户输入正确为止。此功能本因在程序中得以体现,但因对C语言编程掌握的不够全面和深入,加上时间不太充分,此程序中没有体现出来,是我编程工作中的失误,再以后还需加深学习并改进!
【针对第三点:程序功能完善问题】
>>改进思路:
[管理员对运动员的成绩输入]设计思路:将裁判的评给分数全部读入,并且全部进行简单的排序,通过去掉排序后首尾最高和最低分,求出相应的歌手的平均成绩,再将平均值与每个裁判的打分进行比较,与平均值差值最大的定位此次打分中最不公平的裁判,与平均值差值最小的定为此次打分中最公平的裁判!
第七部分:附录(原程序)
#include<>
#include <>
#include <>
#include<>
struct test
{
int num;
float s;
};
void main()
{
int i,j,k,bad,good;
float ts,m,sum=0,aver=0,tm[10];
double min;
struct test score[10],*Judge[10],*temp;
do{
sum=0;
aver=0;
printf("请选择:继续请按1,退出请按2\n");
scanf("%f",&m);
if(m==2)
exit(0);
for(i=0;i<10;i++)
{
printf("请第%d位评委打分\n",i+1);
score[i].num=i+1;
scanf("%f",&score[i].s); /*分数的输入部分*/ if(score[i].s>100||score[i].s<1)
{
printf("分数在1-100之间,请重新输入\n");