#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 dfs( int u )
{
for( int i = 0; i < v[u].size(); i++ )
{
int to = v[u][i];
if( !vis[to] )
{
vis[to] = 1;
if( link[to] == -1 || dfs( link[to] ) )
{
link[to] = u;
return 1;
}
}
}
return 0;
}
int main()
{
int tot;
scanf("%d", &tot);
while(tot--)
{
scanf("%d%d", &n, &m);
int z, x;
for( int i = 1; i <= n; i++ )
v[i].clear();
for( int i = 1; i <= m; i ++ )
{
scanf("%d%d", &z, &x);
v[z].push_back(x);
}
memset(link, -1, sizeof(link));
int ans = 0;
for( int i = 1; i <= n; i++)
{
memset( vis, 0, sizeof( vis ));
ans += dfs( i );
}
printf("%d\n", n - ans);
}
return 0;
}
hdu 1151 Air Raid
最新推荐文章于 2022-04-21 00:08:00 发布