图解剑指offer 18 数据流中的中位数

一、题目描述
在这里插入图片描述
二、大致思路
在这里插入图片描述
在这里插入图片描述
PriorityQueue原理详见:
https://blog.csdn.net/qq_37767455/article/details/98632444
三、代码实现

/* 大顶堆,存储左半边元素   */
    private PriorityQueue<Integer> left = new PriorityQueue<>(((o1, o2) -> o2 - o1));

    /* 小顶堆,存储右半边元素,并且右半边元素都大于左半边 */
    private PriorityQueue<Integer> right = new PriorityQueue<>();

    /* 当前数据流 流入的元素个数 */
    private int N = 0;

    public void insert(Integer val){
        /*  插入  要保证两个堆处于平衡状态 */
        if(N % 2 == 0){
            /*
            N 为偶数的情况下 插入到右半边。
            因为右半边元素都要大于左半边,但是新插入的元素不一定比左半边元素大
            因此需要先将元素插入左半边,然后利用左半边为大顶堆的特点,取出堆顶元素即为最大元素,此时插入右半边
             */
            left.add(val);
            right.add(left.poll());

        }else {
            right.add(val);
            left.add(right.poll());
        }
        N ++;
    }

    public Double getMedian(){
        if(N % 2 == 0){
            return (left.peek() + right.peek()) / 2.0;
        }else{
            return (double)right.peek();
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值