bzoj1452 最大流

时间:2023-03-09 20:51:30
bzoj1452 最大流

很明显最大流。。

#include<bits/stdc++.h>
#define LL long long
#define fi first
#define se second
#define mk make_pair
#define pii pair<int, int> using namespace std; const int N = + ;
const int M = 1e4 + ;
const int inf = 0x3f3f3f3f;
const LL INF = 0x3f3f3f3f3f3f3f3f;
const int mod = 1e9 +; int a[N], b[N], Map[N][N], head[N], level[N], n, sum, tot, S, T; struct node {
int to, w, nx;
} edge[N * N]; void add(int u, int v, int w) {
edge[tot].to = v;
edge[tot].w = w;
edge[tot].nx = head[u];
head[u] = tot++; edge[tot].to = u;
edge[tot].w = ;
edge[tot].nx = head[v];
head[v] = tot++;
} bool bfs() {
memset(level, , sizeof(level));
queue<int> que; level[S] = ; que.push(S);
while(!que.empty()) {
int u = que.front(); que.pop();
if(u == T) return true;
for(int i = head[u]; ~i; i = edge[i].nx) {
int v = edge[i].to, w = edge[i].w;
if(level[v] || w <= ) continue;
level[v] = level[u] + ;
que.push(v);
}
}
return false;
} int dfs(int u, int p) {
if(u == T) return p;
int ret = ;
for(int i = head[u]; ~i; i = edge[i].nx) {
int v = edge[i].to, w = edge[i].w;
if(level[v] != level[u] + || w <= ) continue;
int f = dfs(v, min(w, p - ret));
ret += f;
edge[i].w -= f;
edge[i ^ ].w += f;
if(ret == p) break;
}
if(!ret) level[u] = ;
return ret;
} int Dinic() {
int ans = ;
while(bfs()) ans += dfs(S, inf);
return ans;
}
void init() {
memset(head, -, sizeof(head));
tot = ; sum = ;
} int main() { int cas; scanf("%d", &cas);
while(cas--) {
init();
scanf("%d", &n);
for(int i = ; i <= n; i++) scanf("%d", &a[i]);
for(int i = ; i <= n; i++) scanf("%d", &b[i]); for(int i = ; i <= n; i++)
for(int j = ; j <= n; j++)
scanf("%d", &Map[i][j]); for(int i = ; i <= n; i++)
Map[i][i] = ; S = , T = * n + ; for(int i = ; i <= n; i++)
if(!a[i] || (a[i] && !b[i]))
add(S, i, ), sum++; for(int i = ; i <= n; i++)
if(a[i]) add(i + n, T, ); for(int i = ; i <= n; i++) {
if(a[i] && b[i]) continue;
for(int j = ; j <= n; j++) {
if(Map[i][j] && a[j]) {
add(i, j + n, );
}
}
} if(Dinic() == sum) printf("%c%c%c\n", , , );
else printf("%c%c%c\n", , , );
}
return ;
}
/*
*/