#include #include #include #include #include #include using namespace std; #define ll int #define N 20050 #define M 105000 #define inf 10737418 struct Edge{ ll from, to, cap, nex; }edge[M*4]; ll head[N], edgenum; void add(ll u, ll v, ll cap){ Edge E = { u, v, cap, head[u]}; edge[ edgenum ] = E; head[u] = edgenum ++; Edge E2= { v, u, 0, head[v]}; edge[ edgenum ] = E2; head[v] = edgenum ++; } ll sign[N]; bool BFS(ll from, ll to){ memset(sign, -1, sizeof(sign)); sign[from] = 0; queueq; q.push(from); while( !q.empty() ){ int u = q.front(); q.pop(); for(ll i = head[u]; i!=-1; i = edge[i].nex) { ll v = edge[i].to; if(sign[v]==-1 && edge[i].cap) { sign[v] = sign[u] + 1, q.push(v); if(sign[to] != -1)return true; } } } return false; } ll Stack[N], top, cur[N]; ll dinic(ll from, ll to){ ll ans = 0; while( BFS(from, to) ) { memcpy(cur, head, sizeof(head)); ll u = from; top = 0; while(1) { if(u == to) { ll flow = inf, loc; for(ll i = 0; i < top; i++) if(flow > edge[ Stack[i] ].cap) { flow = edge[Stack[i]].cap; loc = i; } for(ll i = 0; i < top; i++) { edge[ Stack[i] ].cap -= flow; edge[Stack[i]^1].cap += flow; } ans += flow; top = loc; u = edge[Stack[top]].from; } for(ll i = cur[u]; i!=-1; cur[u] = i = edge[i].nex) if(edge[i].cap && (sign[u] + 1 == sign[ edge[i].to ]))break; if(cur[u] != -1) { Stack[top++] = cur[u]; u = edge[ cur[u] ].to; } else { if( top == 0 )break; sign[u] = -1; u = edge[ Stack[--top] ].from; } } } return ans; } void init(){memset(head,-1,sizeof head);edgenum = 0;} char mp[15][15]; int n, m, T; int Hash(int x,int y){return x*m+y;} vectorE,P; int dis[150][150], step[4][2]={1,0,-1,0,0,1,0,-1}; bool vis[150][150]; void bfs(int sx,int sy){ int start = Hash(sx,sy); memset(vis, 0, sizeof vis); vis[sx][sy] = 1; dis[start][start] = 0; queueqx,qy; while(!qx.empty())qx.pop(); while(!qy.empty())qy.pop(); qx.push(sx), qy.push(sy); while(!qx.empty()){ int x = qx.front(), y = qy.front(); qx.pop(); qy.pop(); for(int i = 0; i < 4; i++){ int dx = x + step[i][0], dy = y + step[i][1]; if(!(0<=dx&&dx>1; if(ok(mid))ans = min(ans, mid), r = mid-1; else l = mid+1; } if(T