/**
题目:poj3041 Asteroids
链接:http://poj.org/problem?id=3041
题意:给定n*n的矩阵,'X'表示障碍物,'.'表示空格;你有一把枪,每一发子弹可以消除一行或者一列的障碍物,
问最少需要多少颗子弹可以清空障碍物? 思路:最小点集覆盖问题,等价于最大匹配。把所有的行看做二分图的左边的节点,所有的列看做二分图右边的节点。
如果f[i][j]==true;那么第i行与第j列有关系,连一条边。对这个二分图求最大匹配即可。
采用匈牙利算法。 匈牙利算法学习推荐网址:http://blog.csdn.net/dark_scope/article/details/8880547/
*/ #include<iostream>
#include<cstdio>
#include<algorithm>
#include<map>
#include<vector>
#include<queue>
#include<set>
#include<cstring>
using namespace std;
int f[][];
int vis[], g[];
int n;
///模板
bool Find(int x)
{
for(int i = ; i <= n; i++){///n表示右侧点数。
if(f[x][i]&&vis[i]==){
vis[i] = ;
if(g[i]==||Find(g[i])){
g[i] = x;
return true;
}
}
}
return false;
}
int main()
{
int m;
while(scanf("%d%d",&n,&m)==)
{
int x, y;
memset(f, , sizeof f);
for(int i = ; i <= m; i++){
scanf("%d%d",&x,&y);
f[x][y] = ;
}
int ans = ;
memset(g, , sizeof g);
///模板
for(int i = ; i <= n; i++){
memset(vis, , sizeof vis);
if(Find(i)) ans++;
}
printf("%d\n",ans);
}
return ;
}

最新文章

  1. EasyUI 开发笔记(二)
  2. 慕课网-Java入门第一季-7-2 Java 中无参无返回值方法的使用
  3. requirejs模块化框架用法分享
  4. 28.USB的传输类型
  5. 折腾了好久的macos+apache+php+phpmyadmin 终于成功了!
  6. JSP编程中常用的JavaScript技术(转载)
  7. bzoj2763: [JLOI2011]飞行路线 分层图+dij+heap
  8. c# 使用递归 循环遍历导航树结构 并解析
  9. 【剑指offer】面试题27:二叉搜索树与双向链表
  10. 正则表达式、find、grep、awk、sed
  11. Redis进阶实践之十五 Redis-cli命令行工具使用详解第二部分(结束)
  12. ArrayList、Vector、LinkedList、HashMap、HashTable的存储性能和特性
  13. Chrome Inspect调试微信出现空白页面的解决方法
  14. log4net 写入 mongodb+Mongodb记录日志
  15. 与Servlet相关的类
  16. Python&#160;Elasticsearch批量操作客户端
  17. vue运行说明
  18. ubuntu安装thrift
  19. Android 倒计时按钮,倒计时发送短信验证码…
  20. noi2017 day2t2

热门文章

  1. c/c++的|、||、&amp;、&amp;&amp;、异或、~、!运算
  2. 服务器提交了协议冲突. Section=ResponseHeader Detail=CR...的解决方案总结
  3. tmux入门 : 3. 会话
  4. Redis源代码解析:13Redis中的事件驱动机制
  5. 【Statistics】均值
  6. windowsclient开发--怎样測量一个字符串显示的物理长度
  7. Hashtable insert failed. Load factor too high. The most common cause is multiple threads writing to the Hashtable simultaneously
  8. T-sql for xml path使用
  9. wps标准格式
  10. java基础讲解05-----流程控制语句