[Go练习]跳水比赛8个评委打分问题(存在多个最差评委版)

2023-11-07 09:52

本文主要是介绍[Go练习]跳水比赛8个评委打分问题(存在多个最差评委版),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一,思路:

这道题其实很简单,只需要把成绩排好序保存在一个新的切片里,再对其进行操作就行了

因为最大值和最小值就存在于排好序的切片里的最左边和最右边

并且,在通过舍弃掉最左边和最右边的元素求出最终成绩后,接下来要求的最佳成绩和最差成绩与最终成绩在排好序的切片中的关系同样仅仅是左右关系

最后,在求出最差成绩和最佳成绩后,把它们拿去存放原始成绩的数组里进行比对就可以求出它们分别是第几个评委所打的分数了

二,代码:

package mainimport ("fmt"
)/*
跳水比赛,8个评委打分,运动员的成绩是8个成绩中去掉一个最高分,去掉一个最低分,
剩下6个成绩的平均分就是最终得分。使用一维数组实现以下功能:
1.把打最高分的评委和打最低分的评委找出来
2.找出最佳评委和最差评委。
最佳评委就是打分和最终成绩最接近的评委,最差评委就是打分和最终成绩相差最大的评委
*///冒泡排序函数
func scoreBubble(score []float32) (bubble []float32) {var temp float32for k := 0; k < len(score)-1; k++ {for i := 0; i < len(score)-1-k; i++ {if score[i] > score[i+1] {temp = score[i]score[i] = score[i+1]score[i+1] = temp}}}return score
}//求最终成绩的函数
func finalScore(bubbleScore []float32) float32 {//去掉排序好的成绩的第一个成绩和最后一个成绩finalScoreList := bubbleScore[1 : len(bubbleScore)-1]//遍历去掉头和尾的成绩,求出最终成绩var sum float32for i := 0; i < len(finalScoreList); i++ {sum += finalScoreList[i]}return sum / float32(len(finalScoreList))
}//求出最差评委所打分数的函数
//最差评委:用最终得分和最高成绩(即数组最末尾的元素)及最低成绩(即数组第一个元素)相减
//如果最低成绩和最终成绩的差大于最高成绩和最终成绩的差,那么最差评委就是打最低成绩的那个评委
func worstJudge(finalScore float32, bubbleScore []float32) float32 {if (finalScore - bubbleScore[0]) > (bubbleScore[len(bubbleScore)-1] - finalScore) {return bubbleScore[0]} else {return bubbleScore[len(bubbleScore)-1]}
}//求出最佳评委所打分数的函数
//最佳评委:用最终成绩和每一个评委打出的成绩求差,差最小的为最佳评委
//用最终成绩左右两边最接近的成绩分别与最终成绩求差,差最小的为最佳评委
func bestJudge(finalScore float32, bubbleScore []float32) float32 {var finalLeft float32var finalRight float32for i := 0; i < len(bubbleScore); i++ {if finalScore > bubbleScore[i] {finalLeft = bubbleScore[i]finalRight = bubbleScore[i+1]}}if (finalScore - finalLeft) < (finalRight - finalScore) {//如果最终成绩左边的成绩与最终成绩的差小于最终成绩右边与最终成绩的差,//那么最佳评委是打出最终成绩左边的成绩的评委return finalLeft} else {return finalRight}
}func main() {var rowScore = [8]float32{5, 6.5, 9, 5, 9.5, 7, 5.5, 9.5} //将原始成绩单独保存//新建一个数组用来存放原始成绩,目的是防止排序操作后原始成绩也跟着排序,//如果原始成绩也跟着排序,那么就无法比对出最佳和最差成绩所在的位置了var score = [8]float32{}score = rowScore //将原始成绩赋给新建数组bubbleScore := score[:]                //对其切片处理,目的是传入函数bubbleScore = scoreBubble(bubbleScore) //调用将成绩排序的函数,并接收返回值finalScore := finalScore(bubbleScore) //调用求最终成绩的函数,并接收返回值fmt.Printf("最终成绩为:%.1f\n", finalScore)worstJudge := worstJudge(finalScore, bubbleScore) //调用求最差成绩的函数,并接收返回值bestJudge := bestJudge(finalScore, bubbleScore) //调用求最佳成绩的函数,并接收返回值//最后将最差成绩和最佳成绩放到原始成绩里比对,找出其所在位置fmt.Println("原始成绩:", rowScore)for i := 0; i < len(rowScore); i++ {if rowScore[i] == worstJudge {fmt.Printf("最差评委是打%.1f分的评委,该分数被第%d个评委打出\n", worstJudge, i)}}for i := 0; i < len(rowScore); i++ {if rowScore[i] == bestJudge {fmt.Printf("最佳评委是打%.1f分的评委,该分数被第%d个评委打出\n", bestJudge, i)}}}

三,效果:

 

这篇关于[Go练习]跳水比赛8个评委打分问题(存在多个最差评委版)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

Java死锁问题解决方案及示例详解

《Java死锁问题解决方案及示例详解》死锁是指两个或多个线程因争夺资源而相互等待,导致所有线程都无法继续执行的一种状态,本文给大家详细介绍了Java死锁问题解决方案详解及实践样例,需要的朋友可以参考下... 目录1、简述死锁的四个必要条件:2、死锁示例代码3、如何检测死锁?3.1 使用 jstack3.2

解决JSONField、JsonProperty不生效的问题

《解决JSONField、JsonProperty不生效的问题》:本文主要介绍解决JSONField、JsonProperty不生效的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录jsONField、JsonProperty不生效javascript问题排查总结JSONField

Go语言中Recover机制的使用

《Go语言中Recover机制的使用》Go语言的recover机制通过defer函数捕获panic,实现异常恢复与程序稳定性,具有一定的参考价值,感兴趣的可以了解一下... 目录引言Recover 的基本概念基本代码示例简单的 Recover 示例嵌套函数中的 Recover项目场景中的应用Web 服务器中