题意:

  有两台不同机器A和B,他们分别拥有各种运行模式1~n和1~m。现有一些job,需要在某模式下才能完成,job1在A和B上需要的工作模式又可能会不一样。两台机器一开始处于0模式,可以切换模式,但是仅在0模式才有切换权,可以通过重启机器回到0模式。现在有一堆job,要多少次重启机器才可以完成任务。

思路:

  分析下,很明显,只要求重启次数,那么和时间无关(可以完全由1个机器来干活),只要同个模式的任务能在一块执行掉就节省重启次数了,所有模式一样的任务只耗费1次重启。但是两台机器协作可能重启次数更少,比如在1模式下,B能执行掉2个任务,但是这两个任务需要在A机器上的两种不同模式下才能执行。

  我们的目的是尽量让某一个机器的一种模式能够尽可能多的完成这样的一些任务,这些任务需要在另一台机器的多种模式下完成。

  可以这样建模:左边是S集{机器A的每种模式为1个点},所以有n种模式。右边是T集{机器B的每种模式为1个点},所以有m种模式。每个任务作为一条边,连接S和T上的对应模式。

  按最坏情况考虑,只需要将n+m种模式都运行一次,必定可以解决所有的任务。但是为了节省重启次数,只需要挑出部分的点,能覆盖到所有的边(边即任务)。这样的模型就是二分图的最小点覆盖了。

  求最小点覆盖的定义:对于图G=(V,E)中的一个包含最少的点的集合S⊆V,E中每一条边至少有一个端点在S中。

  根据konig定理,最小点覆盖数=最大匹配数。那么求二分图的最大匹配就行了,可以用匈牙利算法,代码少。(匈牙利算法看“知识科普”分类)

  直接变成了男女配对的模型,A的模式是都是男的,B的模式都是女的。

 #include <bits/stdc++.h>
using namespace std;
const int N=;
int n ,m, k, r, a, b; bool mapp[N][N]; //矩阵
bool match[N]; //用于找路径,走过的点被标记
bool vis[N]; //标记女的是否已经被匹配了
int girl[N]; //假设B为女的 //假设A为男,B为女
int find(int x) //为x找女对象
{
for(int i=; i<=m; i++) //扫描所有妹子
{
if( mapp[x][i] && !match[i] ) //认识的,还没有尝试过帮这个妹子另外找过对象
{
match[i]=; //这个妹子已经试图帮她找过对象了
if(!vis[i] || find(girl[i]))
{
girl[i]=x; //如果能为妹子男朋友另找对象,那么这个妹子就是我的了
vis[i]=;
return true;
}
}
}
return false;
} int hungary()
{
int cnt=;
for(int i=; i<=n; i++)
{
memset(match,,sizeof(match));
if(find(i)) cnt++; //又一个匹配了
}
return cnt;
} int main()
{
freopen("input.txt", "r", stdin);
while(scanf("%d",&n), n)
{
scanf("%d%d",&m,&k);
memset(mapp,,sizeof(mapp));
memset(vis,,sizeof(vis));
memset(girl,,sizeof(girl));
for(int i=; i<k; i++)
{
scanf("%d%d%d",&r,&a,&b);
//if(a>0&&b>0)
mapp[a][b]=; //看作有向边,因为男女的编号可能相同的
}
printf("%d\n",hungary()); //匈牙利算法
}
return ;
}

AC代码

HDU 1150 Machine Schedule (最小覆盖,匈牙利算法)的更多相关文章

  1. hdoj 1150 Machine Schedule【匈牙利算法+最小顶点覆盖】

    Machine Schedule Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  2. hdu 1150 Machine Schedule 最小覆盖点集

    题意:x,y两台机器各在一边,分别有模式x0 x1 x2 ... xn, y0 y1 y2 ... ym, 现在对给定K个任务,每个任务可以用xi模式或者yj模式完成,同时变换一次模式需要重新启动一次 ...

  3. 匈牙利算法模板 hdu 1150 Machine Schedule(二分匹配)

    二分图:https://blog.csdn.net/c20180630/article/details/70175814 https://blog.csdn.net/flynn_curry/artic ...

  4. hdu 1150 Machine Schedule(二分匹配,简单匈牙利算法)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1150 Machine Schedule Time Limit: 2000/1000 MS (Java/ ...

  5. hdu 1150 Machine Schedule(最小顶点覆盖)

    pid=1150">Machine Schedule Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/327 ...

  6. 二分图最大匹配(匈牙利算法)简介& Example hdu 1150 Machine Schedule

    二分图匹配(匈牙利算法) 1.一个二分图中的最大匹配数等于这个图中的最小点覆盖数 König定理是一个二分图中很重要的定理,它的意思是,一个二分图中的最大匹配数等于这个图中的最小点覆盖数.如果你还不知 ...

  7. hdu 1150 Machine Schedule hdu 1151 Air Raid 匈牙利模版

    //两道大水……哦不 两道结论题 结论:二部图的最小覆盖数=二部图的最大匹配数 有向图的最小覆盖数=节点数-二部图的最大匹配数 //hdu 1150 #include<cstdio> #i ...

  8. hdu 1150 Machine Schedule 最少点覆盖转化为最大匹配

    Machine Schedule Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php? ...

  9. hdu 1150 Machine Schedule 最少点覆盖

    Machine Schedule Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php? ...

随机推荐

  1. Hadoop集群中pig工具的安装过程记录

    在Hadoop环境中安装了pig工具,安装过程中碰到了一些问题,在此做一下记录:   主要安装流程参考:http://www.cnblogs.com/yanghuahui/p/3768270.html ...

  2. org.hibernate.service.classloading.spi.ClassLoadingException: Specified JDBC Driver com.mysql.jdbc.Driver class not found

    今天在使用hibernate搭建开发环境的时候出现了一个不可思议的问题: org.hibernate.service.classloading.spi.ClassLoadingException: S ...

  3. 【BZOJ】【1022】【SHOI2008】小约翰的游戏John

    博弈论 一看题,哇这不是Nim游戏么= =直接异或起来……啊咧怎么不对? 这道题是[Anti-Nim],普通的Nim是取走最后一个就赢,这题是取走最后一个输…… 做法参见 2009年贾志豪论文< ...

  4. 【BZOJ】【1086】 【SCOI2005】王室联邦

    树分块 orz vfk && PoPoQQQ http://vfleaking.blog.163.com/blog/static/174807634201231684436977/ h ...

  5. 导入 github 步骤

    https://github.com/dotnet/corefx       如果出现未能找到解决方案的情况,则找项目文件打开,如:  

  6. CString向char类型转化 ---“=”: 无法从“wchar_t *”转换为“char *

    此文从网上复制过来,原文出处已丢失,望见谅哈       VC 2005中,这个本来很简单的问题又稍微复杂了一点.    在工程里面,一个必不可少的步骤就是把CString转换为shar*字符串.通过 ...

  7. iOS开发网络编程之断点续传-NSURLConnection

    最近在做一个小项目的时候,发现使用NSURLSession或者AFNNetworking进行断点续传时诸多的不便,于是自己封装了一个类来实现断点续传,在程序重新启动时仍然可以继续下载(需自己调用方法) ...

  8. springMVC+ibatis数据持久化入门级学习例子

    1.web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app version=" ...

  9. First Lua function running in C

    这是我在C里面跑出来的第一个Lua 文件, 纪念一下. 1.Set up envirnonment: Mac下面 Lua的src (即include) 和lib(binary)是分开的, 所以需要分别 ...

  10. windows下安装ubantu

        首先声明我是一个linux大菜鸟,之所以学这个,一个是好玩,另外做DL的一些软件如Caffe要在这个平台上运行,所以没事就鼓捣鼓捣.linux是一种内核,市场上支持这种内核的操作系统有uban ...