程序:
/*
Copyright (c) 2013, 烟台大学计算机学院
* All rights reserved.
* 作 者:赵玲玲
* 完成日期:2013 年 1 月 16 日
* 版 本 号:v1.0
* 例题:题目条件不变,但考虑同时对评委评分进行裁判,即在10个评委中找出最公平(即评分最接返平均分)
和最不公平(即与平均分的差距最大)的评委,程序应该怎样实现?
* 输入描述: 略
* 问题描述:经典100例题
* 程序输出:略
* 问题分析:外加循环,根据差值求结果
* 算法设计:略
*/
#include <iostream>
#include <cstdio>
using namespace std;
int main()
{
double a[10]={0},max=-1,min=100,ave,sum=0,grade,t1,t2,b[10];
int i;
freopen("grade.txt","r",stdin);
for(i=0;i<10;i++)
{
cout<<"请输入第"<<i+1<<"位评委的打分(1-100分):";
cin>>grade;
if(grade<1||grade>100) //判断输入是否合理
{
cout<<"error!"<<endl;
cout<<"please input again!"<<endl;
i-=1; //一开始是"main();",想弄个循环,输入有错就一直进行main函数,结果出现问题。
//就又加了一个变量grade,若合格再复制给a数组
}
else
{
a[i]=grade;
}
cout<<endl;
}
for(i=0;i<10;i++)
{
if(max<a[i])
{
max=a[i];
}
if(min>a[i])
{
min=a[i];
}
sum+=a[i]; //先求出综合,这样就不用在后面再求最后得分的时候用循环了
}
cout<<"去掉一个最高分"<<max<<"分,\n去掉一个最低分"<<min<<"分"<<endl;
ave=(sum-max-min)/8; //只是要把那两个分减掉
cout<<"该选手最后得分为:"<<ave<<"分"<<endl;
for(i=0;i<10;i++)
{
b[i]=a[i]-ave; //b[] 用来装与最后得分的差值
if(b[i]<0) //保证差为正数
{
b[i]*=-1;
}
}
for(i=1;i<10;i++)
{
if(b[0]>b[i]) //假设b[o]为差值最小者
{
t1=i; //找出最小的,就是最公平的
}
if(b[0]<b[i])
{
t2=i;
}
}
cout<<"第"<<t1<<"位评委最公平。"<<endl;
cout<<"第"<<t2<<"位评委最不公平。"<<endl;
return 0;
}
文件
98 79 86.5 98.4 86.5 74.3 89.2 97 96 88
结果:
体会:额。。。还好吧,