天天看點

HDU 1150 Machine Schedule 最小點覆寫

想一想最小點覆寫時的那種性質,很容易就會産生要把能生産一種産品的機器連線的想法。我今天看這個題,又像以前一樣,看着看着就自動把題意給忘了然後自己進行了腦補,誤以為一個産品能用一台機器的一種以上模式生産,結果不能建圖,以後一定引以為戒!

另一個神奇之處就是mod_0這個事。顯然,能用mod_0及解決的産品根本就不用參與比對。一開始想在一開始對産品進行處理,但其實這很傻,聰明的做法是進行匈牙利算法的時候不枚舉0這個點。

#include<iostream>
#include<cstdio>
#include<string.h>
#include<algorithm>
using namespace std;

int n,m,k,line[210][210],girl[210],used[210];

bool find(int x)
{
    int i,j;
    for (int j=1; j<m; j++)
    {
        if (line[x][j] && !used[j])
        {
            used[j]=1;
            if (girl[j]==-1 || find(girl[j]))
            {
                girl[j]=x;
                return true;
            }
        }
    }
    return false;
}

int main()
{
    while (~scanf("%d",&n) && n)
    {
        scanf("%d%d",&m,&k);
        memset(line,0,sizeof(line));
        for (int i=1; i<=k; i++)
        {
            int z,x,y;
            scanf("%d%d%d",&z,&x,&y);
            line[x][y]=1;
        }
        int all=0;
        memset(girl,-1,sizeof(girl));
        for (int i=1; i<n; i++)
        {
            memset(used,0,sizeof(used));
            if (find(i)) all++;
        }
        cout<<all<<endl;
    }
    return 0;
}