PKU 3041 Asteroids 最小点覆盖(最大匹配模板题)
题目大意:给你一个N*N的矩阵, 里面有K个星球, 我们可以让武器攻击矩阵的一行或者一列来使得这个星球被击碎, 现在问你最少需要几个这种武器才能把所有的星球击碎?
解题思路:关键是建模构图
把每一行当成一个行节点(也当成一把武器,因为一把武器可以消灭一行),构成集合1,每一列当成一个列节点(也当成一把武器,因为一把武器可以消灭一列),构成集合2,则共有2*N(N个行节点,N个列节点,即2*N把武器)节点。若某行某列有一个障碍物,则该行节点和该列节点之间构成一条边。每一个障碍物的位置坐标将集合1与集合2中的点连接起来,也就是将每一个障碍物作为连接节点的边。假设1个行节点覆盖了5个列节点,即这个行节点与这5个列节点间有5条边(即五个障碍物),由于这5条边都被那个行节点覆盖,即表明这5个障碍物都在同一行上,于是可以一把武器全部清除。这样可以轻易的得出本题是一个最小点覆盖的问题。又有一个定理是:最小点覆盖数 = 最大匹配数,所以此题转化成求最大匹配数,有几把武器匹配成功,即需要射击几次,匹配成功的武器越多,射击的次数也就越少。
#include<iostream>
#include<cstring>
using namespace std;
bool vis[];
int n,k,x,y;
int graph[][],link[];
bool Find(int x)
{
for(int i=;i<=n;i++){
if(graph[x][i]&&!vis[i]){
vis[i]=;//为了下一条语句中调用find做准备的,以免重复
if(!link[i]||Find(link[i])){
link[i]=x;
return true;
}
}
}
return false;
} int main()
{
memset(link,,sizeof(link));
memset(graph,,sizeof(graph));
cin>>n>>k;
for(int i=;i<=k;i++){
cin>>x>>y;
graph[x][y]=;
}
int ans=;
for(int i=;i<=n;i++){
memset(vis,,sizeof(vis));
if(Find(i))
ans++;
}
cout<<ans<<endl;
}
PKU 3041 Asteroids 最小点覆盖(最大匹配模板题)的更多相关文章
- poj 3041 Asteroids(最小点覆盖)
		
http://poj.org/problem?id=3041 Asteroids Time Limit: 1000MS Memory Limit: 65536K Total Submissions ...
 - poj 3041 Asteroids 最小点覆盖/最大匹配
		
Asteroids Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16242 Accepted: 8833 Descriptio ...
 - [poj] 3041 Asteroids || 最小点覆盖=最大二分图匹配
		
原题 本题为最小点覆盖,而最小点覆盖=最大二分图匹配 //最小点覆盖:用最少的点(左右两边集合的点)让每条边都至少和其中一个点关联. #include<cstdio> #include&l ...
 - POJ 3041 Asteroids (最小点覆盖集)
		
题意 给出一个N*N的矩阵,有些格子上有障碍,要求每次消除一行或者一列的障碍,最少消除多少次可以全部清除障碍. 思路 把关键点取出来:一个障碍至少需要被它的行或者列中的一个消除. 也许是最近在做二分图 ...
 - POJ 3041 Asteroids     最小点覆盖 == 二分图的最大匹配
		
Description Bessie wants to navigate her spaceship through a dangerous asteroid field in the shape o ...
 - Asteroids POJ - 3041 二分图最小点覆盖
		
Asteroids POJ - 3041 Bessie wants to navigate her spaceship through a dangerous asteroid field in ...
 - Asteroids POJ - 3041 【最小点覆盖集】
		
Bessie wants to navigate her spaceship through a dangerous asteroid field in the shape of an N x N g ...
 - 【POJ 3041】Asteroids (最小点覆盖)
		
每次选择清除一行或者一列上的小行星.最少选择几次. 将行和列抽象成点,第i行为节点i+n,第j列为节点j,每个行星则是一条边,连接了所在的行列. 于是问题转化成最小点覆盖.二分图的最小点覆盖==最大匹 ...
 - poj  3041 Asteroids  (二分图的最大匹配    第一题)
		
题目:http://poj.org/problem?id=3041 题意:在某个n*n的空间内,分布有一些小行星,某人在里面打炮,放一枪后某一行或某一列的行星就都没了,让求最少的打炮数. 然后把每行x ...
 
随机推荐
- poj 1696:Space Ant(计算几何,凸包变种,极角排序)
			
Space Ant Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 2876 Accepted: 1839 Descrip ...
 - 工作流JBPM_day01:1-说明_MyProcessDesigner_流程设计器
			
工作流JBPM_day01:1-说明 先只做请假功能,怎么做? (请假可以和考勤整合到一起) 1,银行(拿号---叫号---办理) 2,餐馆(点菜---上菜---结账) 3,网购(下订单--配送--收 ...
 - 83、android的消息处理机制(图+源码分析)——Looper,Handler,Message
			
转载:http://www.cnblogs.com/codingmyworld/archive/2011/09/12/2174255.html https://my.oschina.net/u/139 ...
 - 我使用过的Linux命令之sftp - 安全文件传输命令行工具
			
用途说明 sftp命令可以通过ssh来上传和下载文件,是常用的文件传输工具,它的使用方式与ftp类似,但它使用ssh作为底层传输协议,所以安全性比ftp要好得多. 常用方式 格式:sftp <h ...
 - springMVC问题
			
网站中springmvc.xml配置: <bean id="viewResolver" class="org.springframework.web.servlet ...
 - klg-jpa:spring-data-jpa 最佳实践
			
klg-jpa:spring-data-jpa 最佳实践 项目介绍 码云地址:https://gitee.com/klguang/klg-jpa JPA是sun为POJO持久化制定的标准规范,用来操作 ...
 - spring could Windows打包构建docker镜像到linux
			
工程模拟参考:http://blog.csdn.net/forezp/article/details/70198649 一.工程结构 二.Pom配置 <build> <plugins ...
 - 初级Java面试题 - JavaSE篇
			
p{font-size:18px;} li{font-size:18px;} 加入我的QQ群(701974765) 获取更多好用又好玩的软件,还有不定期发放的福利呦(- ̄▽ ̄)- Java基本数据类型 ...
 - 160303、js加密跟后台加密对应
			
md5.js var hexcase = 0; var b64pad = ""; var chrsz = 8; function hex_md5(s){ return binl2h ...
 - 160603、使用pd4ml.jar和ss_css2.jar转pdf的工具类
			
注意:需要导入pd4ml.jar和ss_css2.jar import java.awt.Insets;import java.io.BufferedInputStream;import java.i ...