poj3041 Asteroids 匈牙利算法 最小点集覆盖问题=二分图最大匹配
2024-08-25 06:18:43
/**
题目: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 ;
}
最新文章
- EasyUI 开发笔记(二)
- 慕课网-Java入门第一季-7-2 Java 中无参无返回值方法的使用
- requirejs模块化框架用法分享
- 28.USB的传输类型
- 折腾了好久的macos+apache+php+phpmyadmin 终于成功了!
- JSP编程中常用的JavaScript技术(转载)
- bzoj2763: [JLOI2011]飞行路线 分层图+dij+heap
- c# 使用递归 循环遍历导航树结构 并解析
- 【剑指offer】面试题27:二叉搜索树与双向链表
- 正则表达式、find、grep、awk、sed
- Redis进阶实践之十五 Redis-cli命令行工具使用详解第二部分(结束)
- ArrayList、Vector、LinkedList、HashMap、HashTable的存储性能和特性
- Chrome Inspect调试微信出现空白页面的解决方法
- log4net 写入 mongodb+Mongodb记录日志
- 与Servlet相关的类
- Python&#160;Elasticsearch批量操作客户端
- vue运行说明
- ubuntu安装thrift
- Android 倒计时按钮,倒计时发送短信验证码…
- noi2017 day2t2
热门文章
- c/c++的|、||、&;、&;&;、异或、~、!运算
- 服务器提交了协议冲突. Section=ResponseHeader Detail=CR...的解决方案总结
- tmux入门 : 3. 会话
- Redis源代码解析:13Redis中的事件驱动机制
- 【Statistics】均值
- windowsclient开发--怎样測量一个字符串显示的物理长度
- Hashtable insert failed. Load factor too high. The most common cause is multiple threads writing to the Hashtable simultaneously
- T-sql for xml path使用
- wps标准格式
- java基础讲解05-----流程控制语句