题目
题目链接:https://www.luogu.com.cn/problem/P1168
思路
用一个迭代器让它一直在中位数就好了
代码
#include<cstdio>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<cctype>
#include<ctime>
#include<iostream>
#include<string>
#include<map>
#include<queue>
#include<stack>
#include<set>
#include<vector>
#include<iomanip>
#include<list>
#include<bitset>
#include<sstream>
#include<fstream>
#include<complex>
#include<algorithm>
#if __cplusplus >= 201103L
#include <unordered_map>
#include <unordered_set>
#endif
#define ll long long
using namespace std;
const int INF = 0x3f3f3f3f;
multiset<int> st;//multiset里面能够有重复元素,重复元素在原来元素右边。
int main(){
ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int n;
cin>>n;
int pre=-1;
int t1;
cin>>t1;
st.insert(t1);
auto it=st.begin();//定义一个迭代器来记录当前位置的值
cout<<*it<<endl;
pre=*it;
int flag=0;
for(int i=2;i<=n;i++){
int t;
cin>>t;
st.insert(t);
if(pre>t) flag--;
if(pre<=t) flag++;
if(i%2==1){
if(flag==2) it++;//迭代器只能--++,不能+2+3...
if(flag==-2) it--;
cout<<*it<<endl;
pre=*it;
flag=0;
}
}
return 0;
}