码迷,mamicode.com
首页 > 其他好文 > 详细

【剑指offer】【】41. 数据流中的中位数

时间:2020-05-03 20:26:14      阅读:66      评论:0      收藏:0      [点我收藏+]

标签:find   while   offer   instant   anti   you   中位数   amp   iat   

class MedianFinder {
public:
    /** initialize your data structure here. */
    MedianFinder() {

    }
    priority_queue<int> max_heap;
    priority_queue<int, vector<int>, greater<int>> min_heap;
    void addNum(int num) {
        max_heap.push(num);
        while(min_heap.size() && min_heap.top() < max_heap.top())
        {
            auto minv =min_heap.top(), maxv = max_heap.top();
            min_heap.pop(), max_heap.pop();
            max_heap.push(minv), min_heap.push(maxv);
        }
        if(max_heap.size() > min_heap.size() + 1)
        {
            min_heap.push(max_heap.top());
            max_heap.pop();
        }
    }
    
    double findMedian() {
        if(max_heap.size() + min_heap.size() & 1) return max_heap.top();
        return (max_heap.top() + min_heap.top()) / 2.0;
    }
};

/**
 * Your MedianFinder object will be instantiated and called as such:
 * MedianFinder* obj = new MedianFinder();
 * obj->addNum(num);
 * double param_2 = obj->findMedian();
 */

【剑指offer】【】41. 数据流中的中位数

标签:find   while   offer   instant   anti   you   中位数   amp   iat   

原文地址:https://www.cnblogs.com/Trevo/p/12823120.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!