最小点覆盖---最大二分匹配。
题目中有个容易被忽视的地方,两台机器的初始状态都是mode 0。而处理的方法也是很有意思,就是直接忽略那些和左右0节点相连的边。
#include<iostream>
using namespace std;
bool map[105][105];
bool visited[105];
int pre[105];
int n,m,k;
bool Find_DFS(int left)
{
for(int i=0;i<m;i++)
{
if(map[left][i]&&!visited[i])
{
visited[i]=true;
if(pre[i]==-1||Find_DFS(pre[i]))
{
pre[i]=left;
return true;
}
}
}
return false;
}
int main()
{
//freopen("F:\\input.txt","r",stdin);
while(scanf("%d%d%d",&n,&m,&k)==3)
{
memset(map,0,sizeof(map));
memset(pre,-1,sizeof(pre));
int index,s,t;
for(int i=0;i<k;i++)
{
scanf("%d%d%d",&index,&s,&t);
if(s*t==0) continue;
map[s][t]=true;
}
int ans=0;
for(int i=0;i<n;i++)
{
memset(visited,0,sizeof(visited));
if(Find_DFS(i)) ans++;
}
printf("%d\n",ans);
}
return 0;
}