#include using namespace std; typedef long long ll; templatebool chmax(T &a, const T &b) { if (abool chmin(T &a, const T &b) { if (b #define vl vector #define vii vector> #define vll vector> #define vvi vector> #define vvl vector> #define vvii vector>> #define vvll vector>> #define vst vector #define pii pair #define pll pair #define pb push_back #define all(x) (x).begin(),(x).end() #define mkunique(x) sort(all(x));(x).erase(unique(all(x)),(x).end()) #define fi first #define se second #define mp make_pair #define si(x) int(x.size()) const int mod=998244353,MAX=500005,INF=15<<26; //強連結成分分解 int V,cmp[MAX]; vector G[MAX],rG[MAX],vs;//vsがトポソの逆順になってる bool used[MAX]; int get_id(int i,bool f){ return 2*i+f; } void add_edge(int from,int to){ G[from].push_back(to); rG[to].push_back(from); } void either(int i,bool f,int j,bool g){ add_edge(get_id(i,!f),get_id(j,g)); add_edge(get_id(j,!g),get_id(i,f)); //add_edge(2*i+(!f),2*j+g); //add_edge(2*j+(!g),2*i+f); } void imply(int i,bool f,int j,bool g){ either(i,!f,j,g); } //iがfならばjがg void must(int i,bool f){ either(i,f,i,f); } void DFS(int v){ used[v]=1; for(int i=0;i=0;i--){ if(used[vs[i]]==0) rDFS(vs[i],k++); } return k; } void init(int sz){ V=sz; for(int i=0;i par,size,edge; void init(int n_){ n=n_; par.assign(n,-1); size.assign(n,1); edge.assign(n,0); for(int i=0;i>N>>M>>K; init(N); for(int i=0;i>a>>b;a--;b--; add_edge(a,b); } UF uf;uf.init(N+N); int KK=scc(); vi deta; for(int i=0;i