#include using namespace std; using Int = long long; template inline void chmin(T1 &a,T2 b){if(a>b) a=b;} template inline void chmax(T1 &a,T2 b){if(a > G; vector match,level; BiMatch(){} BiMatch(int L,int R):L(L),R(R),G(L+R),match(L+R,-1),level(L){} void add_edge(int u,int v){ G[u].push_back(v+L); G[v+L].push_back(u); } bool bfs(){ queue q; for(int i=0;ilevel[v]&&dfs(w))){ match[v]=u; match[u]=v; return true; } } return false; } int build(){ int res=0; while(bfs()) for(int i=0;i>n; BiMatch bm(n,n); for(int i=0;i>a; for(int j=0;j