牛客OJ:两个堆完成数据流中位数的查询

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ShellDawn/article/details/88949187
#include <bits/stdc++.h>
using namespace std;

priority_queue<int> qmax;  // 多放一个
priority_queue<int, vector<int>, greater<int> > qmin;

void Insert(int num)
{
    if(qmax.empty()){
        qmax.push(num);
        return ;
    }
    int a = qmax.top();
    if(qmin.empty()){
        if(num < a){
            qmax.pop();
            qmax.push(num);
            qmin.push(a);
        }else{
            qmin.push(num);
        }
        return;
    }
    int b = qmin.top();
    if(num >= a && num <= b){
        if((qmax.size() + qmin.size()) & 1){
            qmin.push(num);
        }else{
            qmax.push(num);
        }
        return ;
    }
    if(num < a){
        if((qmax.size() + qmin.size()) & 1){
            qmax.pop();
            qmax.push(num);
            qmin.push(a);
        }else{
            qmax.push(num);
        }
        return ;
    }
    if((qmax.size() + qmin.size()) & 1){
        qmin.push(num);
    }else{
        qmin.pop();
        qmin.push(num);
        qmax.push(b);
    }
}

double GetMedian()
{
    int a = qmax.size();
    int b = qmin.size();
    if(a <= 0) return 0;
    if(b <= 0) return qmax.top();
    if( (a+b)&1 ){
        return qmax.top();
    }else{
        return (qmax.top() + qmin.top()) * 0.5;
    }
}

int main(){
    int a[] = {5,2,3,4,1,6,7,0,8};
    for(int i=0;i<9;i++){
        Insert(a[i]);
        cout<<GetMedian()<<endl;
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/ShellDawn/article/details/88949187