#pragma GCC optimize("Ofast") #pragma GCC target("avx2") #define rd_skip() while(*rp++>=48) #define rd(v) long v=0;{long _c;while(_c=*rp++-48,_c>=0)v=v*10+_c;} #define wt(v) {long _z=v;do*--wp=_z%10+48;while(_z/=10);} #define UFSIZE 200001 int ufbuf[UFSIZE]; int ufval[UFSIZE]; void uf_init(){ for(int i=0;i=0) t=b; while(b=ufbuf[a],b>=0) ufbuf[a]=t,a=b; return t; } void uf_unite(int a,int b){ a=uf_root(a); b=uf_root(b); if(a!=b){ if(1){ ufbuf[a]+=ufbuf[b]; ufbuf[b]=a; }else{ ufbuf[b]+=ufbuf[a]; ufbuf[a]=b; ufval[b]=ufval[a]; } } } long f1(){ char*mmap(); char*rp=mmap(0l,1l<<25,1,2,0,0ll); rd_skip(); long lo=0; long hi=200001; long z=0; while(*rp){ rd(a); long x=ufval[uf_root(a)]; if(x-lo){ if(x*2