歌星大奖赛

/*         
* 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;
}

歌星大奖赛_第1张图片

你可能感兴趣的:(歌星大奖赛)