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

诸位有何高见请不吝赐教

全部评论

相关推荐

一只乌鸦:这不才9月吗,26到明年毕业前能一直找啊,能拿下提前批,转正的,offer打牌的都是有两把刷子的,为什么非要跟他们比。如果别人是9本硕+金牌+好几段大厂实习呢?如果别人是双非通天代呢?如果别人是速通哥呢?,做好自己就行了,我们做不到他们一样提前杀死比赛,但晚点到终点也没啥关系吧
双非应该如何逆袭?
点赞 评论 收藏
分享
代码飞升_不回私信人...:啊喂笨蛋算法为什么写查找,线程池怎么放计网上去了,写动态规划真的不会被狠狠地制裁吗oi
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务