#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<vector>
using namespace std;
#define N 1005
int link[N], vis[N];
vector<int> v[N];
int n, m, k;
int l[N], r[N];
bool mat[N][N];
int dfs( int u )
{
for( int i = 1; i <= m; i ++ )
{
if( !vis[i] && mat[u][i] )
{
vis[i] = 1;
if( link[i] == -1 || dfs( link[i] ) )
{
link[i] = u;
return 1;
}
}
}
return 0;
}
int solve()
{
memset(link, -1, sizeof(link));
int ans = 0;
for( int i = 1; i <= n; i++)
{
memset( vis, 0, sizeof( vis ));
ans += dfs( i );
}
return ans;
}
int main()
{
int tmd = 1;
while(~scanf("%d%d%d", &n, &m, &k) )
{
int z, x;
memset( mat, 0, sizeof( mat ));
for ( int i = 1; i <= k; i++ )
{
scanf("%d%d", &l[i], &r[i]);
mat[l[i]][r[i]] = 1;
}
int ans = solve();
int cnt = 0;
for( int i = 1; i <= k; i ++ )
{
mat[l[i]][r[i]] = 0;
int xx = solve();
mat[l[i]][r[i]] = 1;
cnt += (xx != ans);
}
printf("Board %d have %d important blanks for %d chessmen.\n", tmd++, cnt, ans);
}
return 0;
}
hdu 1281 棋盘游戏
最新推荐文章于 2021-08-17 20:35:05 发布