HDU 1045 Fire Net 【二分图匹配】
<题目链接>
题目大意:
这题意思是给出一张图,图中'X'表示wall,'.'表示空地,可以放置炮台,同一条直线上只能有一个炮台,除非有'X'隔开,问在给出的图中最多能放置多少个炮台。
解题分析:
本题可用DFS求解 >>> ,但是二分匹配的想法更加巧妙,效率也更高。二分匹配的主要思想就是,对矩阵的行连通块和列连通块进行标号,然后根据矩阵的每个点,建立对应的行连通块和列连通块之间的待匹配关系,然后利用匈牙利进行正式匹配,这样当某个行联通块与某个列连通块正式确立匹配关系的时候,说明这两个连通块的交点坐标(之一)放碉堡,而它们的其它部分则不能放碉堡。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
int nrow,ncol;
int g[][],linker[];
bool used[];
char map[][];
int maprow[][],mapcol[][];
bool dfs(int u){
for(int v=;v<=ncol;v++)
if(g[u][v]&&!used[v]){
used[v]=true;
if(!linker[v]||dfs(linker[v])){
linker[v]=u;
return true;
}
}
return false;
}
int Hungary(){
int res=;
memset(linker,,sizeof(linker)); //将行连通块的归属全部置为空
for(int u=;u<=nrow;u++){
memset(used,,sizeof(used));
if(dfs(u))res++;
}
return res;
}
int main(){
int i,j,n;
while(scanf("%d",&n),n){
memset(mapcol,,sizeof(mapcol));
memset(maprow,,sizeof(maprow));
memset(g,,sizeof(g));
for(i=;i<=n;i++){
for(j=;j<=n;j++){
cin>>map[i][j];
if(map[i][j]=='X')
mapcol[i][j]=maprow[i][j]=-; //X点的行连通编号和列连通编号均标为-1
}
}
int p1=;
nrow=;ncol=;
//给行编号
for(i=;i<=n;i++){
for(j=;j<=n;j++){
while(maprow[i][j]==-&&j<=n) //跳过这一行的X部分
j++;
p1++; //p1代表序号
while(maprow[i][j]!=-&&j<=n){
maprow[i][j]=p1; //给第i行连续的连通块打上相同标号p1
if(nrow<p1) nrow=p1; //记录所有行中,行联通块的最大编号
j++;
}
}
}
int p2=;
//给列编号
for(j=;j<=n;j++)
for(i=;i<=n;i++){
while(mapcol[i][j]==-&&i<=n) //遍历第j列的时候,跳过X部分
i++;
p2++;
while(mapcol[i][j]!=-&&i<=n){
mapcol[i][j]=p2; //给第j列的连续的联通块标上相同的序号
if(ncol<p2)ncol=p2; //记录下所有列中,列连通块的最大标号
i++;
}
}
for(i=;i<=n;i++)
for(j=;j<=n;j++){
if(maprow[i][j]!=-&&mapcol[i][j]!=-)
g[maprow[i][j]][mapcol[i][j]]=; //将每个空格点的行连通标号与列连通标号 构建匹配关系
}
printf("%d\n",Hungary());
}
return ;
}
2018-11-10
HDU 1045 Fire Net 【二分图匹配】的更多相关文章
- hdu 1045 Fire Net 二分图匹配 && HDU-1281-棋盘游戏
题意:任意两个个'车'不能出现在同一行或同一列,当然如果他们中间有墙的话那就没有什么事,问最多能放多少个'车' 代码+注释: 1 //二分图最大匹配问题 2 //难点在建图方面,如果这个图里面一道墙也 ...
- HDU 1045 Fire Net 二分图建图
HDU 1045 题意: 在一个n*n地图中,有许多可以挡住子弹的墙,问最多可以放几个炮台,使得炮台不会相互损害.炮台会向四面发射子弹. 思路: 把行列分开做,先处理行,把同一行中相互联通的点缩成一个 ...
- hdu 1045 Fire Net(二分匹配 or 暴搜)
Fire Net Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
- HDU - 1045 Fire Net (二分图最大匹配-匈牙利算法)
(点击此处查看原题) 匈牙利算法简介 个人认为这个算法是一种贪心+暴力的算法,对于二分图的两部X和Y,记x为X部一点,y为Y部一点,我们枚举X的每个点x,如果Y部存在匹配的点y并且y没有被其他的x匹配 ...
- HDU 1045 Fire Net(行列匹配变形+缩点建图)
题意:n*n的棋盘上放置房子.同一方同一列不能有两个,除非他们之间被墙隔开,这种话. 把原始图分别按行和列缩点 建图:横竖分区.先看每一列.同一列相连的空地同一时候看成一个点,显然这种区域不可以同一时 ...
- HDOJ(HDU).1045 Fire Net (DFS)
HDOJ(HDU).1045 Fire Net [从零开始DFS(7)] 点我挑战题目 从零开始DFS HDOJ.1342 Lotto [从零开始DFS(0)] - DFS思想与框架/双重DFS HD ...
- HDU 1045 Fire Net 【连通块的压缩 二分图匹配】
题目:http://acm.hdu.edu.cn/showproblem.php?pid=1045 Fire Net Time Limit: 2000/1000 MS (Java/Others) ...
- hdu 1045 Fire Net(二分图)
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1045 题目大意为给定一个最大为4*4的棋盘,棋盘可以放置堡垒,处在同一行或者同一列的堡垒可以相互攻击, ...
- HDU 1045(Fire Net)题解
以防万一,题目原文和链接均附在文末.那么先是题目分析: [一句话题意] 给定大小的棋盘中部分格子存在可以阻止互相攻击的墙,问棋盘中可以放置最多多少个可以横纵攻击炮塔. [题目分析] 这题本来在搜索专题 ...
- HDU1045:Fire Net(二分图匹配 / DFS)
Fire Net Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
随机推荐
- oracle数据库定时任务dbms_job的用法详解
本文来源:Ruthless <oracle数据库定时任务dbms_job的用法详解> 一.dbms_job涉及到的知识点 1.创建job: variable jobno number; ...
- cordova AndroidStudio3.0 升级报错问题
http://blog.csdn.net/z_Xiaozuo/article/details/78962701 ionic3 打包 安卓项目遇到的问题,当时比较冲忙升级了下android studio ...
- day04 运算符 流程控制 (if while/of)
1. 运算符算数运算符 + - * / int / float :数字类型 # print(10 + 3.1)# print(10 / 3)# print(10 // 3)# print(10 % 3 ...
- SpringAOP面向切面编程
Spring中三大核心思想之一AOP(面向切面编程): 在软件业,AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的 ...
- Django框架之第三篇模板语法(重要!!!)
一.什么是模板? 只要是在html里面有模板语法就不是html文件了,这样的文件就叫做模板. 二.模板语法分类 一.模板语法之变量:语法为 {{ }}: 在 Django 模板中遍历复杂数据结构的关键 ...
- LeetCode(76): 最小覆盖子串
Hard! 题目描述: 给定一个字符串 S 和一个字符串 T,请在 S 中找出包含 T 所有字母的最小子串. 示例: 输入: S = "ADOBECODEBANC", T = &q ...
- 【sqli-labs】Less17
Less17: POST注入,UPDATE语句,有错误回显 新知识点: 1. update注入方法 参考:http://www.mamicode.com/info-detail-1665678.htm ...
- AI学习吧-REDIS-常识
Redis 是一个non-sql,非关系型数据库,数据存放在内存中,支持持久化,redis中的数据会在一段时间内和(mysql等数据库)磁盘进行同步,防止丢失,这样也就降低了读数据效率. Redis和 ...
- AI-序列化-查-做接口
序列化最终代码(下边的可以不看) from rest_framework.views import APIView from rest_framework import serializers fro ...
- Flask-WTF中的csrf保护
CSRF 保护 这部分文档介绍了 CSRF 保护. 为什么需要 CSRF? Flask-WTF 表单保护你免受 CSRF 威胁,你不需要有任何担心.尽管如此,如果你有不包含表单的视图,那么它们仍需要保 ...