<题目链接>

题目大意:

这题意思是给出一张图,图中'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 【二分图匹配】的更多相关文章

  1. hdu 1045 Fire Net 二分图匹配 && HDU-1281-棋盘游戏

    题意:任意两个个'车'不能出现在同一行或同一列,当然如果他们中间有墙的话那就没有什么事,问最多能放多少个'车' 代码+注释: 1 //二分图最大匹配问题 2 //难点在建图方面,如果这个图里面一道墙也 ...

  2. HDU 1045 Fire Net 二分图建图

    HDU 1045 题意: 在一个n*n地图中,有许多可以挡住子弹的墙,问最多可以放几个炮台,使得炮台不会相互损害.炮台会向四面发射子弹. 思路: 把行列分开做,先处理行,把同一行中相互联通的点缩成一个 ...

  3. hdu 1045 Fire Net(二分匹配 or 暴搜)

    Fire Net Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  4. HDU - 1045 Fire Net (二分图最大匹配-匈牙利算法)

    (点击此处查看原题) 匈牙利算法简介 个人认为这个算法是一种贪心+暴力的算法,对于二分图的两部X和Y,记x为X部一点,y为Y部一点,我们枚举X的每个点x,如果Y部存在匹配的点y并且y没有被其他的x匹配 ...

  5. HDU 1045 Fire Net(行列匹配变形+缩点建图)

    题意:n*n的棋盘上放置房子.同一方同一列不能有两个,除非他们之间被墙隔开,这种话. 把原始图分别按行和列缩点 建图:横竖分区.先看每一列.同一列相连的空地同一时候看成一个点,显然这种区域不可以同一时 ...

  6. HDOJ(HDU).1045 Fire Net (DFS)

    HDOJ(HDU).1045 Fire Net [从零开始DFS(7)] 点我挑战题目 从零开始DFS HDOJ.1342 Lotto [从零开始DFS(0)] - DFS思想与框架/双重DFS HD ...

  7. HDU 1045 Fire Net 【连通块的压缩 二分图匹配】

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1045 Fire Net Time Limit: 2000/1000 MS (Java/Others)    ...

  8. hdu 1045 Fire Net(二分图)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1045 题目大意为给定一个最大为4*4的棋盘,棋盘可以放置堡垒,处在同一行或者同一列的堡垒可以相互攻击, ...

  9. HDU 1045(Fire Net)题解

    以防万一,题目原文和链接均附在文末.那么先是题目分析: [一句话题意] 给定大小的棋盘中部分格子存在可以阻止互相攻击的墙,问棋盘中可以放置最多多少个可以横纵攻击炮塔. [题目分析] 这题本来在搜索专题 ...

  10. HDU1045:Fire Net(二分图匹配 / DFS)

    Fire Net Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

随机推荐

  1. Confluence 6 管理应用服务器内存设置

    应用服务器中的最小和最大 JVM Heap 空间配置将会影响系统的性能.Confluence 管理员可能希望对默认的配置进行修改,基于你系统的负载不同配置情况也会有所不同,请参考页面 Server H ...

  2. angular基础巩固

    angular中的模块化 //定义模块 []为依赖的模块 moduleName可以使用[]模块中定义的controller filter .. var app=angular.module('modu ...

  3. spring-boot与spring-data-JPA的简单整合

    如何在boot中轻松使用JPA <!--首先引入JPA依赖--><dependency> <groupId>org.springframework.boot< ...

  4. laravel 更新验证

    public function update(Request $request, User $user) { // 验证规则. $rules = [ 'email' => [ 'nullable ...

  5. hdu2871 区间合并(类似poj3667)+vector应用

    用vector进行插入和删除操作! 总是有些地方处理不好,对拍了才知道错在哪里,, /* 给定一些操作 reset 清空 new a ,申请最左边的连续a个空间 free a,清空a所在的块 get ...

  6. zoj3471 状态压缩dp基础

    /* dp[S]表示状态S下的最大收益,0表示没有了,1表示还在 */ #include<bits/stdc++.h> using namespace std; <<],mp[ ...

  7. Decimal integer conversion

    问题 : Decimal integer conversion 时间限制: 1 Sec  内存限制: 128 MB 题目描述 XiaoMing likes mathematics, and he is ...

  8. gitlab报错502及处理

    报错截图: 解决: 1.端口问题 如上面写的815端口,那配置文件的8080端口都改成815端口 之后重新载入配置文件,并开启 gitlab-ctl reconfigure gitlab-ctl st ...

  9. 无废话-API-01

    说明 我的开发环境:VS2013 浏览器:谷歌浏览器(Google Chrome) 1创建项目 1.1添加一个 应用程序"ASP.NET MVC 4 Web 应用程序"  1.2选 ...

  10. mongodb数据中的复制(副本集)

    ---恢复内容开始--- 什么是复制 复制提供了数据的冗余备份,并在多个服务器上存储数据副本,提高了数据的可用性,并可以保证数据的安全性 复制还允许从硬件故障和服务中断中恢复数据 为什么要复制 数据备 ...