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

数据流中的中位数

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;
        
    }


}
全部评论

相关推荐

无情咸鱼王的秋招日记之薛定谔的Offer:好拒信,偷了,希望有机会用到
点赞 评论 收藏
分享
双非坐过牢:非佬,可以啊10.28笔试,11.06评估11.11,11.12两面,11.19oc➕offer
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务