洛谷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++ 右值引用(rvalue references)与移动语义(move semantics)深度解析

《C++右值引用(rvaluereferences)与移动语义(movesemantics)深度解析》文章主要介绍了C++右值引用和移动语义的设计动机、基本概念、实现方式以及在实际编程中的应用,... 目录一、右值引用(rvalue references)与移动语义(move semantics)设计动机1

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

C++构造函数中explicit详解

《C++构造函数中explicit详解》explicit关键字用于修饰单参数构造函数或可以看作单参数的构造函数,阻止编译器进行隐式类型转换或拷贝初始化,本文就来介绍explicit的使用,感兴趣的可以... 目录1. 什么是explicit2. 隐式转换的问题3.explicit的使用示例基本用法多参数构造

C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解

《C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解》:本文主要介绍C++,C#,Rust,Go,Java,Python,JavaScript性能对比全面... 目录编程语言性能对比、核心优势与最佳使用场景性能对比表格C++C#RustGoJavapythonjav

C++打印 vector的几种方法小结

《C++打印vector的几种方法小结》本文介绍了C++中遍历vector的几种方法,包括使用迭代器、auto关键字、typedef、计数器以及C++11引入的范围基础循环,具有一定的参考价值,感兴... 目录1. 使用迭代器2. 使用 auto (C++11) / typedef / type alias

C语言逗号运算符和逗号表达式的使用小结

《C语言逗号运算符和逗号表达式的使用小结》本文详细介绍了C语言中的逗号运算符和逗号表达式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习... 在C语言中逗号“,”也是一种运算符,称为逗号运算符。 其功能是把两个表达式连接其一般形式为:表达

Go语言实现桥接模式

《Go语言实现桥接模式》桥接模式是一种结构型设计模式,它将抽象部分与实现部分分离,使它们可以独立地变化,本文就来介绍一下了Go语言实现桥接模式,感兴趣的可以了解一下... 目录简介核心概念为什么使用桥接模式?应用场景案例分析步骤一:定义实现接口步骤二:创建具体实现类步骤三:定义抽象类步骤四:创建扩展抽象类步

GO语言实现串口简单通讯

《GO语言实现串口简单通讯》本文分享了使用Go语言进行串口通讯的实践过程,详细介绍了串口配置、数据发送与接收的代码实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录背景串口通讯代码代码块分解解析完整代码运行结果背景最近再学习 go 语言,在某宝用5块钱买了个

C++ scoped_ptr 和 unique_ptr对比分析

《C++scoped_ptr和unique_ptr对比分析》本文介绍了C++中的`scoped_ptr`和`unique_ptr`,详细比较了它们的特性、使用场景以及现代C++推荐的使用`uni... 目录1. scoped_ptr基本特性主要特点2. unique_ptr基本用法3. 主要区别对比4. u