#include using namespace std; #define int long long #define rep(i,s,n) for(int i = s;i=(s);i--) #define all(v) (v).begin(),(v).end() #define pb push_back #define fi first #define se second #define chmin(a,b) a=min((a),(b)) #define chmax(a,b) a=max((a),(b)) typedef long long ll; typedef pairpint; typedef vectorvint; typedef vectorvpint; typedef pair P1; typedef pair P2; typedef pairPP; static const ll maxLL = (ll)1 << 62; const ll MOD=1000000007; const ll INF=1e18; int dx[]={0,0,1,-1}; int dy[]={-1,1,0,0}; int N,M; int a,b; struct UF{ vectorpar,sz; void init(int n){ par.resize(n); sz.resize(n); for(int i=0;i>N>>M; UF uf; uf.init(N+2); rep(i,0,M){ int a,b;cin>>a>>b; if(uf.size(a)>uf.size(b))uf.unite(a,b); else if(uf.size(a)