标签:要求 超过 统计 highlight 格式 flag void als 思路
题目描述:
在浙大的计算机专业课中,经常有互评分组报告这个环节。一个组上台介绍自己的工作,其他组在台下为其表现评分。最后这个组的互评成绩是这样计算的:所有其他组的评分中,去掉一个最高分和一个最低分,剩下的分数取平均分记为 G?1?? ;老师给这个组的评分记为 G?2?? 。该组得分为 (G?1?? +G?2?? )/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
核心思路:
// 把成绩记录在Score[] 数组中,Score[0] 代表老师的打分
// 统计学生的有效成绩个数和最高最低分
// 最后运算的时候减去两个最值,有效成绩个数也要减去2
printf("%d\n",(int)(((((sum-min_s-max_s)*1.0/num)+Score[0])*1.0/2)+0.5));
本人AC代码:
// 1077 互评成绩计算
# include <stdio.h>
# define Max 101
int main(void)
{
int N, len, num=0, i;
int flag = -1; // flag标记为第一个有效的学生成绩
int M, sum=0, min_s, max_s;
int Score[Max] = {0};
scanf("%d %d",&N,&M);
len = N;
while (len > 0)
{
sum = 0.0;
num = 0;
flag = -1; // 每次都设初值为-1
// 每组进行单独遍历,找出有效成绩个数,找到最大最小值
for (i=0; i<N; i++)
{
// Score[0]为老师评分,不参与G1计算
scanf("%d",&Score[i]);
// 找到第一个有效的学生成绩
if (i>0 && flag==-1)
{
if (Score[i]>=0 && Score[i]<=M)
flag = 0;
}
// 把找到的学生成绩记录为当前的最大最小值
if (0 == flag)
{
// 记录第一个有效的学生成绩
min_s = max_s = Score[i];
flag = 1;
}
// 统计有效分数
if (i>0 && Score[i]>=0 && Score[i]<=M)
{
sum += Score[i];
// 有效分数的个数
num++;
// 更新最大最小值
if (Score[i] > max_s)
max_s = Score[i];
if (Score[i] < min_s)
min_s = Score[i];
}
}
num -= 2;
// 总成绩计算
// 学生成绩为去掉最大最小值的平均值
// 总成绩为学生最终成绩和老师最终成绩均值
printf("%d\n",(int)(((((sum-min_s-max_s)*1.0/num)+Score[0])*1.0/2)+0.5));
len--; // 计算下一组
}
return 0;
}
RRR
标签:要求 超过 统计 highlight 格式 flag void als 思路
原文地址:https://www.cnblogs.com/Robin5/p/11218176.html