专栏首页刷题笔记1077 互评成绩计算 (20 分)

1077 互评成绩计算 (20 分)

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/shiliang97/article/details/99671150

1077 互评成绩计算 (20 分)

在浙大的计算机专业课中,经常有互评分组报告这个环节。一个组上台介绍自己的工作,其他组在台下为其表现评分。最后这个组的互评成绩是这样计算的:所有其他组的评分中,去掉一个最高分和一个最低分,剩下的分数取平均分记为 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

暴露问题:

1.max 默认最小值,min默认最大值 (我给写反了查半天才查出来)

2.输出四舍五入时+0.5 ,float类型直接%d输出就成0了,不能自动转换 要强转

#include<iostream>
using namespace std;
int main(){
	int n,m;
	cin>>n>>m;
	for(int i=0;i<n;i++){
		int  G1,sum=0,max=-1,min=100,b,count=0;
		cin>>G1;
		for(int a=1;a<n;a++){
			cin>>b;
			if(b>=0&&b<=m){
				count++;
				if(b>max){
					max=b;
				}if(b<min){
					min=b;
				}
				sum+=b;
				
			}
		}
		//cout<<"G"<<G1*0.5<<"****"<<((sum-max-min)/(count-2))*0.5<<endl;
		double s= G1*0.5+((sum-max-min)/(count-2))*0.5;
		//cout<<s<<endl;
		printf("%d\n",(int)(s+0.5));
		
	}
	return 0;
}

又是柳婼大神的超短代码比较一下和自己差距很大(是自己比不上人家)

其实思想上差不多哈哈(自我安慰)

#include <iostream>
using namespace std;
int main() {
    int n, m;
    cin >> n >> m;
    for (int i = 0; i < n; i++) {
        int g2, g1 = 0, cnt = -2, temp, maxn = -1, minn = m + 1;
        cin >> g2;
        for (int j = 0; j < n-1; j++) {
            cin >> temp;
            if (temp >= 0 && temp <= m) {
                if (temp > maxn) maxn = temp;
                if (temp < minn) minn = temp;
                g1 += temp;
                cnt++;
            }
        }
        cout << int((((g1 - minn - maxn) * 1.0 / cnt) + g2) / 2 + 0.5) << endl;
    }
    return 0;
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 一个好的新闻App,需要...

    单平台的APP必定让企业舍弃用户,跨平台才是王道。对于中小企业来说,开发自己的APP就意味着需要配置IOS和android的程序员,根据开发难度需要的人员数量不...

    齿轮易创说互联网
  • SpringCloud 注册中心 Eureka 集群是怎么保持数据一致的?

    服务注册中心不可能是单点的,一定会有一个集群,那么集群中的服务注册信息如何在集群中保持一致的呢?

    dys
  • 线程屏障(基于linuxthreads-2.3)

    线程屏障是线程同步的一个方式。线程执行完一个操作后,可能需要等待其他线程也完成某个动作,这时候,当前该线程就会被挂起,直到其他线程也完成了某个操作,最后所有线程...

    theanarkh
  • Linux Kernel 5.4的主要新功能:内核锁定和ExFAT支持

    导语:如果你想知道Linux Kernel 5.4内核有哪些主要新功能和新特性,请继续阅读本文。

    用户6543014
  • ccie-day4

        1.1定义:将本地路由表中一种路由协议所生成的路由翻译成的其他路由发送出去

    郭耀华
  • 把应用置顶显示的小软件Window TopMost控件v1.1

    某些Windows应用程序没有提供使其自身位于最高位置的选项,即使其保持在所有其他窗口之上,而使用Windows Topmost控件则可以将该功能添加到任何窗...

    萌海无涯
  • 微服务的数据库设计

    微服务设计的一个关键是数据库设计,基本原则是每个服务都有自己单独的数据库,而且只有微服务本身可以访问这个数据库。它是基于下面三个原因。

    烂猪皮
  • MySQL 如何查找删除重复行?

    第一步是定义什么样的行才是重复行。多数情况下很简单:它们某一列具有相同的值。本文采用这一定义,或许你对“重复”的定义比这复杂,你需要对sql做些修改。本文要用到...

    芋道源码
  • 时至 2018 年,还有必要学 Vim 吗?

    从上世纪九十年代起到现在 Vim 一直是最流行、应用最广泛的文本编辑器之一。程序员、作家、系统管理员、运维人员以及其他需要与文本文件打交道的人都在积极地使用它。...

    用户6543014
  • Zookeeper leader的选举机制

    所有节点创建具有相同路径 /app/leader_election/guid_ 的顺序、临时节点。 ZooKeeper集合将附加10位序列号到路径,创建的zn...

    用户5760343

扫码关注云+社区

领取腾讯云代金券