1077 互评成绩计算

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

输入格式:

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

思路:简单题,注意四舍五入的写法就行...

写法1:直接用max,min记录最大值和最小值,用sum记录合法的评分总和,最后直接用sum减去max,min再除以(count-2)求得平均评分

 1 #include<stdio.h>
 2 #include<math.h>
 3 #include<string.h>
 4 #include<stdlib.h>
 5 int main()
 6 {
 7     int N,manfen;
 8     scanf("%d %d",&N,&manfen);
 9     double teacherfen,grade;
10     
11     for(int i=0;i<N;i++)
12     {
13         scanf("%lf",&teacherfen);
14         double max=-1,min=999,count=0,sumfen=0;
15         for(int j=0;j<N-1;j++)
16         {
17             scanf("%lf",&grade);
18             if(grade>=0&&grade<=manfen)
19             {
20                 count++;
21                 sumfen=sumfen+grade;
22                 if(grade<min)
23                   min=grade;
24                 if(grade>max)
25                   max=grade;
26             }
27         }
28         double pingjun=(sumfen-max-min)/(count-2);
29         int truegrade=(int)((pingjun+teacherfen+1)/2);
30         printf("%d
",truegrade);
31     }
32         return 0;
33 }

写法2:用C语言里面的快排qsort,排序后弃掉数组首尾求和求值计算

 1 #include<stdio.h>
 2 #include<string.h>
 3 #include<math.h>
 4 #include<stdlib.h>
 5 int cmp(const void *p,const void *q)
 6 {
 7     int x=*(int *)p;
 8     int y=*(int *)q;
 9     if(x>y)
10     return 1;
11     else if(x<y)
12     return -1;
13     return 0;
14 }
15 int main()
16 {
17     int N,manfen;
18     scanf("%d%d",&N,&manfen);
19     int teacherfen;
20     for(int i=0;i<N;i++)
21     {
22         scanf("%d",&teacherfen);
23         int t=0;
24         int grade[N];
25         int fen;
26         for(int j=0;j<N-1;j++)
27         {
28             scanf("%d",&fen);
29             if(fen>=0&&fen<=manfen)
30             grade[t++]=fen;
31         }
32         qsort(grade,t,sizeof(int),cmp);
33         int sumgrade=0;
34         for(int j=1;j<t-1;j++)
35         sumgrade=sumgrade+grade[j];
36         int pingjunfen=sumgrade/(t-2);
37         int truegrade=(pingjunfen+teacherfen+1)/2;
38         printf("%d
",truegrade);
39     }
40     return 0;
41 }
大佬见笑,,
原文地址:https://www.cnblogs.com/xwl3109377858/p/10195915.html