PAT Basic 1077. 互评成绩计算
PAT Basic 1077. 互评成绩计算
1. 题目描述:
在浙大的计算机专业课中,经常有互评分组报告这个环节。一个组上台介绍自己的工作,其他组在台下为其表现评分。最后这个组的互评成绩是这样计算的:所有其他组的评分中,去掉一个最高分和一个最低分,剩下的分数取平均分记为
2. 输入格式:
输入第一行给出两个正整数
3. 输出格式:
为每个组输出其最终得分。每个得分占一行。
4. 输入样例:
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
5. 输出样例:
42
33
41
31
37
39
6. 性能要求:
Code Size Limit
16 KB
Time Limit
400 ms
Memory Limit
64 MB
思路:
除草题,按照题意编写即可。
My Code:
#include <stdio.h>
int main(void)
{
int groupCount = 0, maxGrade = 0;
int i=0; // iterator
//double tempGrade = 0.0;
int validCount = 0;
int tempRes = 0;
//double tempSum = 0.0;
int teacherGrade = 0, tempGrade = 0;
int j=0; // iterator
int tempSum = 0;
int tempMax = 0, tempMin = 0;
scanf("%d%d", &groupCount, &maxGrade);
for(i=0; i<groupCount; ++i)
{
tempSum = 0;
validCount = 0;
tempMax = -1;
tempMin = maxGrade+1;
for(j=0; j<groupCount; ++j)
{
scanf("%d", &tempGrade);
if(!j)
{
teacherGrade = tempGrade; // teacherGrade is always valid
}
else
{
if(tempGrade>=0 && tempGrade <= maxGrade) // if valid
{
if(tempGrade > tempMax)
tempMax = tempGrade;
if(tempGrade < tempMin)
tempMin = tempGrade;
tempSum += tempGrade;
++validCount;
}
}
}
tempSum -= tempMax;
tempSum -= tempMin;
validCount -= 2;
//printf("teacherGrade: %d, tempSum: %d\n", teacherGrade, tempSum);
tempRes = teacherGrade*0.5 + tempSum*0.5/validCount + 0.5;
printf("%d\n", tempRes);
}
return 0;
}
分类:
PAT Basic Level
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现