/*
* Copyright (c) 2012, 烟台大学计算机学院
* All rights reserved.
* 作 者: 刘同宾
* 完成日期:2012 年 12 月 07 日
* 版 本 号:v1.0
*
* 输入描述: 歌星大奖赛
在歌星大奖赛中,有10个评委为参赛的选手打分,分数为1~100分。选手最后得分为:去掉一个最高分和一个最低分后其余8个分数的平均值。
同时对评委评分进行裁判,即在10个评委中找出最公平(即评分最接返平均分)和最不公平(即与平均分的差距最大)的评委,请编写程序实现。
* 问题描述:
* 程序输出:
* 问题分析:略
* 算法设计:略
*/
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
double score[11];
double max,min;
int i;
cout<<"请10位评委依次为选手打分:"<<endl;
for(i=1;i<11;i++) //输入分数
{
cin>>score[i];
}
max=score[1];
min=score[1];
for(i=1;i<11;i++) //找出最大最小值
{
if(score[i]>max)
{
max=score[i];
}
if(score[i]<min)
{
min=score[i];
}
}
double sum=0; //对数组元素求和
for(i=1;i<11;i++)
{
sum=sum+score[i];
}
double averge; //将最大值和最小值去掉在取平均分
averge=(sum-max-min)/8;
cout<<endl<<"平均分为:"<<averge<<endl;
int a,b; //找出评分最高的评委和最低的评委
for(i=1;i<11;i++)
{
if(score[i]==max)
{
a=i;
}
if(score[i]==min)
{
b=i;
}
}
if((max-averge)>(-(min-averge)))//找出最不公平的评委
{
cout<<endl<<"最不公平的是"<<a<<"号评委!!!"<<endl;
}
else
cout<<endl<<"最不公平的是"<<b<<"号评委!!!"<<endl;
//找出最公平的评委
double x=fabs(score[1]-averge);
for(i=1;i<11;i++) //先将最小差值找出来啊
{
if(x>fabs(score[i]-averge))
{
x=fabs(score[i]-averge);
}
}
int y;
for(i=1;i<11;i++) //然后再找出是第几号评委
{
if(x==fabs(score[i]-averge))
{
y=i;
}
}
cout<<endl<<"最公平的是第"<<y<<"号评委!!!"<<endl;
return 0;
}
歌星大奖赛
最新推荐文章于 2021-02-10 17:04:16 发布