HDU 1150 Machine Schedule(二分…

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1150

二分匹配题,题目求最小重启次数,即最小点覆盖,x集合为所有A机器模式,y集合为所有B机器模式,任务为边,求最小点覆盖,即图最大二分匹配,匈牙利算法

 有一点非常坑爹,循环要从1开始,可是我貌似在题中没找到提示(或许我英文解读能力不够?)只看见了个Mode_0,Mode_1,就以为是从0开始循环,结果WA……

代码:

 

#include<stdio.h>
#include<string.h>

int map [ 100 ][ 100 ], m ,n;
int match [ 100 ], visit [ 100 ];

int DFS( int u)
{
    int i;
    for( i = 1; i <= m; i ++)
    {
        if( map [ u ][ i ] && visit [ i ] ==- 1)
        {
            visit [ i ] = 1;
            if( match [ i ] ==- 1 || DFS( match [ i ]))
            {
                match [ i ] = u;
                return 1;
            }
        }
    }
    return 0;
}

int main()
{
    int i , num , a ,b , c;
    while( scanf( "%d" , &n ),n)
    {
        memset( map , 0 , sizeof( map));
        scanf( "%d%d" , & m , & num);
        for( i = 0; i < num; i ++)
        {
            scanf( "%d%d%d" , & a , &b , & c);
            map [b ][ c ] = 1;
        }
        memset( match , - 1 , sizeof( match));
        num = 0;
        for( i = 1; i <=n; i ++)
        {
            memset( visit , - 1 , sizeof( visit));
            if( DFS( i))
                num ++;
        }
        printf( "%d \n " , num);
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值