#pragma GCC optimize("Ofast") #pragma GCC target("avx2") char*mmap(); #define RD(v) int v=0;{int _c;while(_c=*rp++-48,_c>=0)v=v*10+_c;} #define HASHSIZE 1000003 long hash[HASHSIZE]; int hash_k1; int hash_k2; long ab[200000]; long cd[200000]; int en[100001]; int ei[100001]; int eb[400000]; long wbuf[100001]; long d; void f(int i){ if(!wbuf[i]){ wbuf[i]=d; for(int k=0;k=HASHSIZE) k-=HASHSIZE; } hash[k]=e; } for(int i=0;i=HASHSIZE) k-=HASHSIZE; } if(!hash[k]){ int a=e>>32; int b=e; eb[ei[a]+en[a]++]=b; eb[ei[b]+en[b]++]=a; } } d=-1; f(1); for(int i=q;i--;){ d=i+1; int a=cd[i]>>32; int b=cd[i]; if(wbuf[a]) f(b); if(wbuf[b]) f(a); eb[ei[a]+en[a]++]=b; eb[ei[b]+en[b]++]=a; } for(int i=2;i<=n;++i){ int z=wbuf[i]; wbuf[i]= z<0?0x0a2020202020312dl: (z>=100000?z/100000%10+48l:32l)<< 0| (z>= 10000?z/ 10000%10+48l:32l)<< 8| (z>= 1000?z/ 1000%10+48l:32l)<<16| (z>= 100?z/ 100%10+48l:32l)<<24| (z>= 10?z/ 10%10+48l:32l)<<32| z%10+0x0a2030l<<40; } write(1,wbuf+2,(n-1)*8); _exit(0); }