C++实验——参赛歌手计算平均分问题:去掉一个最高分,去掉一个最低分,将剩下分数的平均值作为选手的最后成绩。这里假设共有10位评委,都是按照百分制打分。
话不多说,先上我写的代码然后讨论:
//歌唱大赛选手成绩计算
//去掉一个最高分,去掉一个最低分,将剩下分数的平均值作为选手的最后成绩。这里假设共有10位评委,都是按照百分制打分。
#include <iostream>
#include <string>
const int Arsize = 10;
int main()
{
using namespace std;
string caption("the score is invalid.\n");
int score[Arsize];
int sum = 0;
double average;
for (int i = 0; i < Arsize; i++) cin >> score[i];
int max = score[0];
int min = score[0];
for (int j = 0; j < Arsize; j++)
{
if (score[j] > max)
max = score[j];
if (score[j] <min)
min = score[j];
}
for (int n = 0; n < Arsize; n++)
{
if (score[n] < 0 || score[n]>100)
{
cout << caption;
return 0;
}
else
{
sum += score[n];
}
}
average = (sum - max - min) / 8.0;
cout << average << endl;
return 0;
}
编译通过了,但是总感觉傻傻的,用了很多for语句,执行效率感觉不高,
求最值也可以通过这个库函数实现:
#include<algorithm>
int max = *max_element(score, score + 10);int min = *min_element(score, score + 10);
诸位有何高见请不吝赐教