华为OD机考:统一考试 D卷 + C卷 + B卷 +A卷
真题目录:华为OD机考机试 真题目录(C卷 + D卷 + B卷 + A卷) + 考点说明
题目描述:查找众数及中位数(本题分值100)
众数是指一组数据中出现次数量多的那个数,众数可以是多个。
中位数是指把一组数据从小到大排列,最中间的那个数,如果这组数据的个数是奇数,那最中间那个就是中位数,如果这组数据的个数为偶数,那就把中间的两个数之和除以2,所得的结果就是中位数。
查找整型数组中元素的众数并组成一个新的数组,求新数组的中位数。
输入描述
输入一个一维整型数组,数组大小取值范围 0<N<1000,数组中每个元素取值范围 0<E<1000
输出描述
输出众数组成的新数组的中位数
用例
输入 | 10 11 21 19 21 17 21 16 21 18 15 |
输出 | 21 |
输入 | 2 1 5 4 3 3 9 2 7 4 6 2 15 4 2 4 |
输出 | 3 |
输入 | 5 1 5 3 5 2 5 5 7 6 7 3 7 11 7 55 7 9 98 9 17 9 15 9 9 1 39 |
输出 | 7 |
题目解析
题目要求找到整型数组中的众数,可以使用哈希表来统计每个数出现的次数,然后找到出现次数最多的数,即为众数。如果有多个众数,都放入一个新数组中。接着,对新数组进行排序,找到其中位数即可。
具体步骤如下:
-
使用哈希表统计每个数出现的次数,找到出现次数最多的数,即为众数。如果有多个众数,都放入一个新数组中。
-
对新数组进行排序,找到其中位数。