#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; typedef long long int llint; #define mp make_pair #define mt make_tuple #define pub push_back #define puf push_front #define pob pop_back #define pof pop_front #define fir first #define sec second #define res resize #define ins insert #define era erase const int mod=1000000007; const int big=1e9+10; const long double pai=3.141592653589793238462643383279502884197; const long double eps=1e-9; template void mineq(T& a,U b){if(a>b){a=b;}} template void maxeq(T& a,U b){if(a>n>>m; vectorboss(n);//自分のうえ vectornum(n); for(i=0;i>a>>b;a--;b--; while(boss[a]!=a){a=boss[a];} while(boss[b]!=b){b=boss[b];} if(a==b){continue;} if(num[a]b){swap(a,b);} //aがかつ num[a]+=num[b]; boss[b]=a; } for(i=0;i