HDU1150二分图最小顶点覆盖

HDU1150二分图最小顶点覆盖
二分图的最小顶点覆盖=二分图的最大匹配。
证明见 http://hi.baidu.com/keeponac/blog/item/1764bec86f820f8dc91768b7.html
关键是分析题意:A,B两台机器,A有n个模式,B有m个模式,要完成K个任务,每个任务可以在A的i模式下完成,也可以在B的j模式下完成,求最少的模式切换次数,也就是用最少的模式覆盖所有的任务,将模式看成顶点,将任务看成边,也就是第k个任务可以由A的i模式覆盖或B的j模式覆盖,求最小顶点覆盖。由于任意一个任务不能用同一个机器的不同模式完成,且任务不分顺序,所以该图是二分图,分为两个模式集合。
// 二分图的最小顶点覆盖等于二分图的最大匹配
#include  < iostream >

using   namespace  std;

const   int  M = 101 ;
bool  g[M][M];
bool  visit[M];
int   link[M];
int   m,n,k;

bool  find( int  i)
{
    
int j;
    
for(j=1;j<=m;j++)
    
{
        
if(g[i][j] && !visit[j])
        
{
            visit[j]
=true;
            
if(link[j]==0 || find(link[j]))
            
{
                link[j]
=i;
                
return true;
            }

        }

    }

    
return false;
}


int  main()
{
    
int i,j,t,res;
    
while(cin>>n,n)
    
{
        memset(g,
0,sizeof(g));
        memset(link,
0,sizeof(link));
        res
=0;
        cin
>>m>>k;
        
while(k--)
        
{
            cin
>>t>>i>>j;
            g[i][j]
=true;
        }

        
for(i=1;i<=n;i++)
        
{
            memset(visit,
0,sizeof(visit));
            
if(find(i))
                res
++;
        }

        cout
<<res<<endl;
    }

    
return 0;
}


你可能感兴趣的:(HDU1150二分图最小顶点覆盖)