• 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 }
    大佬见笑,,
  • 相关阅读:
    软件工程敏捷开发06
    学习进度条
    软件工程敏捷开发05
    软件工程敏捷开发04
    敏捷开发用户场景分析
    软件工程敏捷开发03
    软件工程敏捷开发02
    软件工程敏捷开发01
    面向对象程序设计(一)
    Java介绍、环境的搭建及结构化程序
  • 原文地址:https://www.cnblogs.com/xwl3109377858/p/10195915.html
Copyright © 2020-2023  润新知