5、寻找数据流的中位数

寻找数据流的中位数:

代码实现
/**
 * 设计一个数据结构:
 * 得到一个数据流的中位数
 */
public class MedianFinder {

    PriorityQueue<Integer> bigHeap;
    PriorityQueue<Integer> smallHeap;

    public MedianFinder() {
        bigHeap = new PriorityQueue<>(((o1, o2) -> o2 - o1));
        smallHeap = new PriorityQueue<>();
    }

    public void addNum(int val) {
        bigHeap.add(val);
        smallHeap.add(bigHeap.poll());

        if (bigHeap.size() + 1 < smallHeap.size()) {
            bigHeap.add(smallHeap.poll());
        }
    }

    public double findMedian() {
        if (smallHeap.size() > bigHeap.size())
            return smallHeap.size();

        return (double) (smallHeap.peek() + bigHeap.peek());
    }
}
posted @   HaiXPE  阅读(28)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
点击右上角即可分享
微信分享提示