【timegate】

https://www.luogu.org/problem/P1168

【解题思路】

使用两个堆,大根堆维护较小的值,小根堆维护较大的值

即小根堆的堆顶是较大的数中最小的,大根堆的堆顶是较小的数中最大的

【code】

 1 #include <cstdio>
 2 #include <queue>
 3 #include <cmath>
 4 #include <iostream>
 5 #include <algorithm>
 6 using namespace std;
 7 int n,a;
 8 priority_queue<int> q;
 9 priority_queue<int,vector<int>,greater<int> > qq;
10 int main(){
11     scanf("%d",&n);
12     scanf("%d",&a);
13     q.push(a);
14     printf("%d\n",a);
15     for(register int i=2;i<=n;i++){
16         scanf("%d",&a);
17         if (a>q.top())
18             qq.push(a);
19         else q.push(a);
20         while (q.size()-qq.size()>1){
21             if (q.size()>qq.size()){
22                 qq.push(q.top());
23                 q.pop();
24             }
25             else{
26                 q.push(qq.top());
27                 qq.pop();
28             }
29         }
30         if (i&1)
31             printf("%d\n",q.size()>qq.size()?q.top():qq.top());
32     }
33     return 0;
34 }
01-23 03:01