#include #define syosu(x) fixed< P; typedef pair pdd; typedef pair pll; typedef vector vi; typedef vector vvi; typedef vector vd; typedef vector vvd; typedef vector vl; typedef vector vvl; typedef vector vs; typedef vector

vp; typedef vector vvp; typedef vector vpll; typedef pair pip; typedef vector vip; const int inf=1<<30; const ll INF=1ll<<60; const double pi=acos(-1); const double eps=1e-8; const ull mod=1e9+7; const int dx[4]={-1,0,1,0},dy[4]={0,-1,0,1}; class Graph{ private: int n,N; vvi g,rg; vi scc,used; stack stc; void Order(int v){ used[v]=1; for(auto u:g[v]) if(!used[u]) Order(u); stc.push(v); } void DFS(int v,int t){ used[v]=1; for(auto u:rg[v]) if(!used[u]) DFS(u,t); scc[v]=t; } int SCC(){ scc=used=vi(n); rg=vvi(n); for(int i=0;i>n>>m; Graph g(4*n); a=b=vi(n); for(int i=0;i>a[i]>>b[i]; for(int i=0;i