题目
众数是指一组数据中出现次数量多的那个数,众数可以是多个。
中位数是指把一组数据从小到大排列,最中间的那个数,如果这组数据的个数是奇数,那最中间那个就是中位数,如果这组数据的个数为偶数,那就把中间的两个数之和除以2,所得的结果就是中位数。
查找整型数组中元素的众数并组成一个新的数组,求新数组的中位数。
输入描述
输入一个一维整型数组,数组大小取值范围 0<N<1000,数组中每个元素取值范围 0<E<1000
输出描述
输出众数组成的新数组的中位数
用例
输入
10 11 21 19 21 17 21 16 21 18 15
输出
21
解题思路
遍历数组并使用哈希表记录每个元素出现的频率,找到出现次数最多的元素(众数)并将它们存入一个列表。然后对这个众数列表进行排序,根据列表长度的奇偶性计算中位数,若长度为奇数则中位数为中间元素,若为偶数则中位数为中间两个元素的平均值。
代码
import java.
该博客介绍了如何在华为OD机试中解决众数及中位数查询的问题。首先,解释了众数和中位数的概念,接着描述了解题思路,即通过遍历数组并使用哈希表统计元素频率,找出众数并将其存储,最后对众数列表排序计算中位数。具体解决方案包括遍历、哈希表记录、列表构建和中位数计算过程。
订阅专栏 解锁全文
4463

被折叠的 条评论
为什么被折叠?



