STL的基本用法
(居然能空间卡过去= =!!!)
#include <cstdio> #include <ext/pb_ds/priority_queue.hpp> #include <functional> #include <algorithm> #include <utility> __gnu_pbds::priority_queue<std::pair<int,int>,std::greater<std::pair<int,int> >,__gnu_pbds::pairing_heap_tag> hps[1000005]; int hpl; struct denizer{ struct{ int fa,rk; } d[1000005]; inline int find(int n){ int p=n,f; while(d[p].fa){ p=d[p].fa; } while(n!=p){ f=d[n].fa; d[n].fa=p; n=f; } return p; } bool merge(int& a,int& b){ a=find(a),b=find(b); if(a==b) return 0; if(d[a].rk<d[b].rk) std::swap(a,b); d[b].fa=a; if(d[b].rk==d[a].rk) ++d[a].rk; return 1; } }djset; char s[10]; bool kd[1000005]; int Q; int main(){ int n,i,j,k; scanf("%d",&n); for(i=1;i<=n;++i){ scanf("%d",&j); hps[i].push(std::make_pair(j,i)); } scanf("%d",&Q); while(Q--){ scanf("%s%d",s,&j); switch(s[0]){ case 'M': scanf("%d",&k); if(kd[j]||kd[k]) break; if(djset.merge(j,k)){ hps[j].join(hps[k]); } break; case 'K': if(kd[j]){ printf("0 ");break; } j=djset.find(j); if(!hps[j].empty()) printf("%d ",hps[j].top().first),kd[hps[j].top().second]=true,hps[j].pop(); break; } } return 0; }
直接改了我出题的标程...