二分图最大匹配(匈牙利算法) POJ 3041 Asteroids
/*
题意:每次能消灭一行或一列的障碍物,要求最少的次数。
匈牙利算法:把行和列看做两个集合,当有障碍物连接时连一条边,问题转换为最小点覆盖数==二分图最大匹配数
趣味入门:http://blog.csdn.net/dark_scope/article/details/8880547
*/
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <vector>
using namespace std; const int MAXN = 5e2 + ;
const int INF = 0x3f3f3f3f;
vector<int> G[MAXN];
bool vis[MAXN];
int lk[MAXN]; bool DFS(int u)
{
for (int i=; i<G[u].size (); ++i)
{
int v = G[u][i];
if (!vis[v])
{
vis[v] = true;
if (lk[v] == - || DFS (lk[v]))
{
lk[v] = u; return true;
}
}
}
return false;
} int hungary(int n)
{
int res = ; memset (lk, -, sizeof (lk));
for (int i=; i<=n; ++i)
{
memset (vis, false, sizeof (vis));
if (DFS (i)) res++;
} return res;
} int main(void) //POJ 3041 Asteroids
{
// freopen ("POJ_3041.in", "r", stdin); int n, k;
while (scanf ("%d%d", &n, &k) == )
{
for (int i=; i<=n; ++i) G[i].clear ();
for (int i=; i<=k; ++i)
{
int x, y; scanf ("%d%d", &x, &y);
G[x].push_back (y);
} printf ("%d\n", hungary (n));
} return ;
}
二分图最大匹配(匈牙利算法) POJ 3041 Asteroids的更多相关文章
- 二分图最大匹配(匈牙利算法) POJ 3020 Antenna Placement
		
题目传送门 /* 题意:*的点占据后能顺带占据四个方向的一个*,问最少要占据多少个 匈牙利算法:按坐标奇偶性把*分为两个集合,那么除了匹配的其中一方是顺带占据外,其他都要占据 */ #include ...
 - poj - 3041 Asteroids (二分图最大匹配+匈牙利算法)
		
http://poj.org/problem?id=3041 在n*n的网格中有K颗小行星,小行星i的位置是(Ri,Ci),现在有一个强有力的武器能够用一发光速将一整行或一整列的小行星轰为灰烬,想要利 ...
 - poj 3894 System Engineer (二分图最大匹配--匈牙利算法)
		
System Engineer Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 507 Accepted: 217 Des ...
 - UESTC 919 SOUND OF DESTINY --二分图最大匹配+匈牙利算法
		
二分图最大匹配的匈牙利算法模板题. 由题目易知,需求二分图的最大匹配数,采取匈牙利算法,并采用邻接表来存储边,用邻接矩阵会超时,因为邻接表复杂度O(nm),而邻接矩阵最坏情况下复杂度可达O(n^3). ...
 - Ural1109_Conference(二分图最大匹配/匈牙利算法/网络最大流)
		
解题报告 二分图第一题. 题目描写叙述: 为了參加即将召开的会议,A国派出M位代表,B国派出N位代表,(N,M<=1000) 会议召开前,选出K队代表,每对代表必须一个是A国的,一个是B国的; ...
 - HDU 1045 - Fire Net - [DFS][二分图最大匹配][匈牙利算法模板][最大流求二分图最大匹配]
		
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=1045 Time Limit: 2000/1000 MS (Java/Others) Mem ...
 - HDU1068 (二分图最大匹配匈牙利算法)
		
Girls and Boys Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
 - HDU - 1045 Fire Net  (二分图最大匹配-匈牙利算法)
		
(点击此处查看原题) 匈牙利算法简介 个人认为这个算法是一种贪心+暴力的算法,对于二分图的两部X和Y,记x为X部一点,y为Y部一点,我们枚举X的每个点x,如果Y部存在匹配的点y并且y没有被其他的x匹配 ...
 - 51Nod  2006 飞行员配对(二分图最大匹配)-匈牙利算法
		
2006 飞行员配对(二分图最大匹配) 题目来源: 网络流24题 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 第二次世界大战时期,英国皇家空军从沦陷国 ...
 
随机推荐
- 开车旅行(codevs 1199)
			
题目描述 Description 小A 和小B决定利用假期外出旅行,他们将想去的城市从1到N 编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市 i的海拔高度为Hi, ...
 - vimtips阅读记录
			
__BEGIN__ *vimtips.txt* For Vim version 8.0. ------------------------------------------------------- ...
 - org.springframework.amqp.AmqpIOException: java.net.UnknownHostException: guest解决
			
org.springframework.amqp.AmqpIOException: java.net.UnknownHostException: guest 由于在yml文件中配置的时候误将passw ...
 - 18.9.22 noip模拟赛
			
此题为找规律.期望100 实际100 #include<cstdio> #include<cstring> #include<iostream> #include& ...
 - laravel有用的方法
			
1.tinker 造假数据 factory('App\User',3)->create(); DB::table 返回collection,可以用collection中的很多方法 比如-> ...
 - 信息收集工具recon-ng详细使用教程
			
前言: 最近在找Recon-ng详细一点的教程,可是Google才发现资料都很零散而且不详细,所以我打算具体写一下.Recon-ng在渗透过程中主要扮演信息收集工作的角色,同时也可以当作渗透工具,不过 ...
 - android的ndk学习(1)
			
android的ndk学习(1) 之前学了一段时间ndk,总认为要总结一下.ndk使得很方便地实现java和C与C++代码的相互沟通.合理地掌握使用ndk能够提高应用程序的运行效率.所以对于学习a ...
 - 安装Nginx须要系统的辅助软件(linux)
			
安装Nginx须要系统的辅助软件(linux): yum -y install make gcc gcc-c++ ncurses-devel yum -y install zlib zlib-deve ...
 - asm volatile ("B .")
			
在开发中,我们常常会有有这种需求,就是在某段代码处開始,一步一步往下跟踪调试,有人说加个while(1)循环,事实上这个循环增加后,其后边的代码就会被优化掉,达不到我们的目的,更好的办法是在须要的地方 ...
 - GSON学习笔记之初识GSON
			
引用"JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,採用全然独立于语言的文本格式.为Web应用开发提供了一种理想的数据交换格式. " ...