题解 | #数据流中的中位数#

数据流中的中位数

http://www.nowcoder.com/practice/9be0172896bd43948f8a32fb954e1be1

import java.util.*;
public class Solution {
    // 存放右边元素 如果是奇数时候 保证右边元素比左边元素多1 比如 12345  左边12 右边 345
    PriorityQueue<Integer> minHeap = new PriorityQueue<>();
    // 存放左边元素
    PriorityQueue<Integer> maxHeap = new PriorityQueue<>((a,b)->b-a);
    
    public void Insert(Integer num) {
        if(minHeap.isEmpty() || num > minHeap.peek()) {
            minHeap.add(num);
            if (minHeap.size() - maxHeap.size() >= 2) {
                maxHeap.add(minHeap.poll());
            }
        }else {
            maxHeap.add(num);
            if (maxHeap.si***Heap.size() >= 1) {
                minHeap.add(maxHeap.poll());
            }
        }
    
    }

    public Double GetMedian() {
        return minHeap.size() > maxHeap.size() ? (double)minHeap.peek() : (double)(minHeap.peek() + maxHeap.peek())/2;
        
    }


}
全部评论

相关推荐

ALEX_BLX:这华子能怪谁呢,池子泡这么深,每年几乎都是最晚一批开出来的公司,人才早就给抢走了。又不是人人都是博士生
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务