5729. 求出 MK 平均值
难度困难2
给你两个整数 m 和 k ,以及数据流形式的若干整数。你需要实现一个数据结构,计算这个数据流的 MK 平均值 。
MK 平均值 按照如下步骤计算:
- 如果数据流中的整数少于
m个,MK 平均值 为-1,否则将数据流中最后m个元素拷贝到一个独立的容器中。 - 从这个容器中删除最小的
k个数和最大的k个数。 - 计算剩余元素的平均值,并 向下取整到最近的整数 。
请你实现 MKAverage 类:
MKAverage(int m, int k)用一个空的数据流和两个整数m和k初始化 MKAverage 对象。void addElement(int num)往数据流中插入一个新的元素num。int calculateMKAverage()对当前的数据流计算并返回 MK 平均数 ,结果需 向下取整到最近的整数 。
示例 1:
1 | 输入: |
提示:
3 <= m <= 1051 <= k*2 < m1 <= num <= 105addElement与calculateMKAverage总操作次数不超过105次。
暴力模拟
1 | class MKAverage { |