1077 互评成绩计算——20分

在浙大的计算机专业课中,经常有互评分组报告这个环节。一个组上台介绍自己的工作,其他组在台下为其表现评分。最后这个组的互评成绩是这样计算的:所有其他组的评分中,去掉一个最高分和一个最低分,剩下的分数取平均分记为 G1;老师给这个组的评分记为 G2。该组得分为 (G1+G2)/2,最后结果四舍五入后保留整数分。本题就要求你写个程序帮助老师计算每个组的互评成绩。

输入格式:
输入第一行给出两个正整数N(> 3)和M,分别是分组数和满分,均不超过100。随后N行,每行给出该组得到的N个分数(均保证为整型范围内的整数),其中第1个是老师给出的评分,后面 N-1 个是其他组给的评分。合法的输入应该是[0, M]区间内的整数,若不在合法区间内,则该分数须被忽略。题目保证老师的评分都是合法的,并且每个组至少会有3个来自同学的合法评分。

输出格式:
为每个组输出其最终得分。每个得分占一行。

输入样例:

6 50
42 49 49 35 38 41
36 51 50 28 -1 30
40 36 41 33 47 49
30 250 -25 27 45 31
48 0 0 50 50 1234
43 41 36 29 42 29

输出样例:

42
33
41
31
37
39

| 代码长度限制 | 时间限制 | 内存限制 |
| 16KB | 400ms | 64MB |

代码:

#include<bits/stdtr1c++.h>
using namespace std;
int main() {
	int N, M;
	scanf("%d %d", &N, &M);
	double score;
	vector<double> v; //保存其他组的给分
	double T_s;
	for (int i = 0; i < N; i++) { //一组一组进行处理并输出
		for (int j = 0; j < N; j++) {
			scanf("%lf", &score);
			if (j == 0) T_s = score; //老师给出的分数
			else if (j > 0 && score >= 0 && score <= M) //其他组给出的且在[0,M]区间内的合法分数
				v.emplace_back(score);
		}
		sort(v.begin(), v.end(), greater<int>()); //对其他组给出分数排序
		double ave1 = accumulate(v.begin() + 1, v.end() - 1, 0) / int(v.size() - 2) * 1.0; //去掉最高分和最低分后计算平均分
		double ave2 = round((T_s + ave1) / 2.0); //其他组给出的平均分和老师给的分数再次求平均分,要四舍五入
		printf("%.0f\n", ave2); //输出最终得分,保留整数部分
		v.clear(); //清空vector
	}
	return 0;
}
posted @   Fare-Well  阅读(71)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示