import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import java.util.ArrayList; import java.util.Arrays; import java.util.NoSuchElementException; public class Main { public static void main(String[] args) throws FileNotFoundException { long t = System.currentTimeMillis(); new Main().run(); System.err.println(System.currentTimeMillis() - t); } class SegTree{ int n=1; int[] v; public SegTree(int n) { while(this.n0) { k=(k-1)/2; v[k]=v[2*k+1]+v[2*k+2]; } } int query(int a,int b) { return query(0,n,a,b,0); } int query(int l,int r,int a,int b,int k) { if(a<=l&&r<=b)return v[k]; else if(r<=a||b<=l)return 0; else { int vl=query(l,(l+r)/2,a,b,2*k+1); int vr=query((l+r)/2,r,a,b,2*k+2); return vl+vr; } } } int pointer=0; void dfs(int cur,int par,int[] left,int[] right,ArrayList[] g) { left[cur]=pointer++; for(int dst:g[cur]) { if(dst==par)continue; dfs(dst,cur,left,right,g); } right[cur]=pointer++; } class DJSet{ int n; int[] upper; public DJSet(int n) { this.n=n; upper=new int[n]; Arrays.fill(upper, -1); } int root(int x) { return upper[x]<0?x:(upper[x]=root(upper[x])); } boolean equiv(int x,int y) { return root(x)==root(y); } void setUnion(int x,int y) { x=root(x);y=root(y); if(x==y)return; if(upper[x]0)++sz; for(int i=0;i