洛谷P5738 【深基7.例4】歌唱比赛 C语言/C++

2023-11-02 23:50

本文主要是介绍洛谷P5738 【深基7.例4】歌唱比赛 C语言/C++,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【深基7.例4】歌唱比赛

题目描述

n ( n ≤ 100 ) n(n\le 100) n(n100) 名同学参加歌唱比赛,并接受 m ( m ≤ 20 ) m(m\le 20) m(m20) 名评委的评分,评分范围是 0 0 0 10 10 10 分。这名同学的得分就是这些评委给分中去掉一个最高分,去掉一个最低分,剩下 m − 2 m-2 m2 个评分的平均数。请问得分最高的同学分数是多少?评分保留 2 2 2 位小数。

输入格式

第一行两个整数 n , m n,m n,m
接下来 n n n 行,每行各 m m m 个整数,表示得分。

输出格式

输出分数最高的同学的分数,保留两位小数。

样例 #1

样例输入 #1

7 6
4 7 2 6 10 7
0 5 0 10 3 10
2 6 8 4 3 6
6 3 6 7 5 8
5 9 3 3 8 1
5 9 9 3 2 0
5 8 0 4 1 10

样例输出 #1

6.00

所需变量

int n;//用于存储有多少个人参加比赛

int m;//代表有多少个评委

int arr[101[21];//用于存储每个人的每个评委评分

double ave[101] = {0};//代表每个人去掉最高分,去掉最低分之后的平均分

int sum[101] = {0};//代表每个人的评委打分的总分

int re[101][2];//代表要去除的最高分和最低分,re[i][0]代表最低分,re[i][1]代表最高分

int i,j;//循环变量

double max = 0;//用于存储最高分

思路:我们每当输入一个人(i)的评委评分时,我们就判断这个是不是这个人的最高分,或者是最低分,将其存储进这个人(i)的re数组中,并且把sum获取出来,得到这么多之后我们就可以直接当一个人(i)的评委打分都输入结束就能计算该人的平均分了

for(i = 0;i<n;i++){re[i][0] = 10;//minre[i][1] = 0;//maxfor(j = 0;j<m;j++){cin>>arr[i][j];sum[i] += arr[i][j];if(arr[i][j]<re[i][0]){re[i][0] = arr[i][j];}if(arr[i][j]>re[i][1]){re[i][1] = arr[i][j];}}ave[i] = ((sum[i] - re[i][0] - re[i][1])*1.0)/(m-2);if(max<ave[i]){max = ave[i];}}
ave[i] = ((sum[i] - re[i][0] - re[i][1])*1.0)/(m-2);

然后当每个人都计算结束,我们就能判断这些平均分中的最高分了,然后将其输出出来!
该算法本人认为比较优,如果有更好的想法,欢迎q我!

#include<iostream>
using namespace std;
int main(){int n,m;int arr[101][21];double ave[101] = {0};int sum[101] = {0};int re[101][2];int i,j;double max = 0;cin>>n>>m;for(i = 0;i<n;i++){re[i][0] = 10;//minre[i][1] = 0;//maxfor(j = 0;j<m;j++){cin>>arr[i][j];sum[i] += arr[i][j];if(arr[i][j]<re[i][0]){re[i][0] = arr[i][j];}if(arr[i][j]>re[i][1]){re[i][1] = arr[i][j];}}ave[i] = ((sum[i] - re[i][0] - re[i][1])*1.0)/(m-2);if(max<ave[i]){max = ave[i];}}printf("%.2lf",max);return 0;
}

在这里插入图片描述

这篇关于洛谷P5738 【深基7.例4】歌唱比赛 C语言/C++的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/334147

相关文章

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据