参考自: http://user.qzone.qq.com/289065406/blog/1299322465

解题思路:

把方阵看做一个特殊的二分图(以行列分别作为两个顶点集V1、V2,其中| V1|=| V2|)

然后把每行x或者每列y看成一个点,而障碍物(x,y)可以看做连接x和y的边。按照这种思路构图后。问题就转化成为选择最少的一些点(x或y),使得从这些点与所有的边相邻,其实这就是最小点覆盖问题。

再利用二分图最大匹配的König定理:

最小点覆盖数 = 最大匹配数

(PS:最小点覆盖:假如选了一个点就相当于覆盖了以它为端点的所有边,你需要选择最少的点来覆盖图的所有的边。)

因此本题自然转化为求 二分图的最大匹配 问题

 

求最大匹配的一种显而易见的算法是:先找出全部匹配,然后保留匹配数最多的。但是这个算法的时间复杂度为边数的指数级函数

因此,需要寻求一种更加高效的算法——增广路求最大匹配的方法(匈牙利算法)

增广路的定义(也称增广轨或交错轨):

若P是图G中一条连通两个未匹配顶点的路径,并且属于M的边和不属于M的边(即已匹配和待匹配的边)在P上交替出现,则称P为相对于M的一条增广路径。

由增广路的定义可以推出下述三个结论:

 1、P的路径个数必定为奇数,第一条边和最后一条边都不属于M。

2、将M和P进行取反操作可以得到一个更大的匹配M’

(反操作:把P中的 匹配边 与 非匹配边 互换)

3、M为G的最大匹配当且仅当不存在M的增广路径P

匈牙利算法轮廓:

  (1)置M为空

  (2)找出一条增广路径P,通过异或操作获得更大的匹配M’代替M

  (3)重复(2)操作直到找不出增广路径为止

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
#define Del(x,y) memset(x,y,sizeof(x))
int map[][],vis[],link[];
int n,k; bool dfs(int x)
{
for(int i=;i<=n;i++)
if(map[x][i]==&&vis[i]==)
{
vis[i]=;
if(link[i]==-||dfs(link[i]))
{
link[i]=x;
return true;
}
}
return false;
} void solve()
{
int ans=;
Del(link,-);
for(int i=;i<=n;i++)
{
Del(vis,);
if(dfs(i))
ans++;
}
printf("%d\n",ans);
} int main()
{
int r,c;
scanf("%d%d",&n,&k);
Del(map,);
while(k--)
{
scanf("%d%d",&r,&c);
map[r][c]=;
}
solve();
return ;
}

最新文章

  1. 对C++虚函数的理解
  2. Redis基础(转)
  3. 实现跨云应用——基于DNS的负载均衡
  4. 2016HUAS暑假集训训练2 F - A Simple Problem with Integers
  5. objective c, category 和 protocol 中添加property
  6. 错误名称:EntityCommandExecutionException
  7. LABJS使用教程
  8. 关于tableView的优化
  9. Javascript Date Format
  10. jd-gui 反编译后去除注释
  11. redis sentinel 配置
  12. 图解Java字符串不变性
  13. 获取API返回值
  14. java面向对象之 类和对象
  15. BZOJ 3367: [Usaco2004 Feb]The Big Game 球赛( dp )
  16. Java面经 面试经验 互联网公司面试经验 后端面试经验
  17. Python中的那些“坑”
  18. 【activity任务栈】浅析
  19. vue中的watch方法 实时同步存储数据
  20. oracle like模糊查询简单用法

热门文章

  1. 机器学习笔记——SVM
  2. 【Linux多线程】三个经典同步问题
  3. shell脚本 加密备份MySQL数据库
  4. [Python网络编程]浅析守护进程后台任务的设计与实现
  5. MessageBox.Show
  6. leetcode 258. Add Digits——我擦,这种要你O(1)时间搞定的必然是观察规律,总结一个公式哇
  7. [置顶][终极精简版][图解]Nginx搭建flv mp4流媒体服务器
  8. 将数据从数据仓库Hive导入到MySQL
  9. C++ 值初始化和默认初始化
  10. sql让时间调前,调后的语句