zoukankan      html  css  js  c++  java
  • hdu 1150 Machine Schedule(二分图模板题)

    题目大意:有两台机器A和B,A机器有n种工作方式,B机器有m种工作方式。共有k个任务。每个任务恰好在一条机器上运行。
    如果任务在A机器上运行,就需要转换为模式Xi,如果在B机器上运行,就需要转换为模式Yi
    每台机器上的任务可以按照任意顺序执行,但是每台机器每转换一次模式需要重启一次。
    请合理为每个任务安排一台机器并合理安排顺序,使得机器重启次数尽量少。

    邻接矩阵

    #include <iostream>
    #include <cstdio>
    #include <cstring>
    
    using namespace std;
    
    const int maxn=111;
    
    int n,m,k;
    int g[maxn][maxn];
    int linker[maxn];
    bool used[maxn];
    
    bool dfs(int u)
    {
        for(int v=1;v<=m;v++)
        {
            if(g[u][v]&&used[v]==false)
            {
                used[v]=true;
                if(linker[v]==-1||dfs(linker[v]))
                {
                    linker[v]=u;
                    return true;
                }
            }
        }
        return false;
    }
    
    int hungary()
    {
        int res=0;
        memset(linker,-1,sizeof(linker));
        for(int u=1;u<=n;u++)
        {
            memset(used,false,sizeof(used));
            if(dfs(u)) res++;
        }
        return res;
    }
    
    int main()
    {
        while(scanf("%d",&n),n!=0)
        {
            memset(g,0,sizeof(g));
            scanf("%d%d",&m,&k);
            while(k--)
            {
                int i,u,v;
                scanf("%d%d%d",&i,&u,&v);
                g[u][v]=1;
            }
            cout<<hungary()<<endl;
        }
        return 0;
    }
  • 相关阅读:
    javascript ajax 脚本跨域调用全解析
    [转载]linux sed命令详解
    perl随记(1)
    TCL随记(2)
    TCL随记(1)
    C Shell 中的特殊变量
    异步FIFO为什么用格雷码
    VMM学习-vmm_log
    UVM基础之---Command-line Processor
    Verification Mind Games---how to think like a verifier像验证工程师一样思考
  • 原文地址:https://www.cnblogs.com/Fy1999/p/9669996.html
Copyright © 2011-2022 走看看