首页 > 其他 > 详细

P1484 种树

时间:2020-07-21 15:34:42      阅读:54      评论:0      收藏:0      [点我收藏+]

链接:Miku

---------------------------------

对顶堆做法

---------------------------------

技术分享图片
#include<iostream> 
#include<cstdio>
#include<algorithm>
#include<queue>

using namespace std;
 priority_queue <int,vector<int>,greater<int> > q1;//小顶 
 priority_queue <int,vector<int>,less<int> >q2;//大顶 
 int n,k;
 int x;
int main(){
    scanf("%d",&n);
    for(int i=1;i<=n;++i){
        scanf("%d",&k);
        if(i==1){
        q2.push(k);
        cout<<k<<endl;
        continue;
        }
        else{
            if(q2.top()>k)
            q2.push(k);
            else
            q1.push(k);
        }
        if(q2.size()>q1.size()&&q2.size()-q1.size()>1){//不先比较会有莫名其妙越界问题
            x=q2.top();
            q1.push(x);
            q2.pop();
        }
        if(q1.size()>q2.size()&&q1.size()-q2.size()>1){
            x=q1.top();
            q2.push(x);
            q1.pop();    
        }
        if(i%2){
            if(q2.size()>q1.size())
            cout<<q2.top()<<endl;
            else
            cout<<q1.top()<<endl;
        }
    }
    return 0;
}
Ac

 

P1484 种树

原文:https://www.cnblogs.com/For-Miku/p/13354367.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!