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);

诸位有何高见请不吝赐教

猜你喜欢

转载自blog.csdn.net/fly_wt/article/details/79678682