poj 2446 二分图最大匹配
思路:由(i+j)为偶数的点向(i+j)为奇数的点建边。求一次最大匹配,若正好为空格数(不包含洞)的一半,即输出YES。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define Maxn 1101
using namespace std;
int n,m,vi[Maxn],match[Maxn],graphic[Maxn][Maxn],map[][],N[Maxn],M[Maxn],x,y;
int dfs(int u)
{
int i;
for(i=;i<=y;i++)
{
if(!vi[M[i]]&&graphic[u][M[i]])
{
vi[M[i]]=;
if(match[M[i]]==-||dfs(match[M[i]]))
{
match[M[i]]=u;
return ;
}
}
}
return ;
}
int Pos(int i,int j)
{
return (i-)*n+j;
}
int main()
{
int i,j,t,a,b,k;
while(scanf("%d%d%d",&m,&n,&k)!=EOF)
{ memset(match,-,sizeof(match));
memset(graphic,,sizeof(graphic));
memset(map,,sizeof(map));
for(i=;i<=k;i++)
{
scanf("%d%d",&a,&b);
map[b][a]=;
}
x=y=;
for(i=;i<=m;i++)
{
for(j=;j<=n;j++)
{
if((i+j)%)
M[++y]=Pos(i,j);
else
N[++x]=Pos(i,j);
if(j<n)
{
if(!map[i][j+]&&!map[i][j])
{
if((i+j)%==)
graphic[Pos(i,j)][Pos(i,j+)]=;
if((i+j)%)
{
graphic[Pos(i,j+)][Pos(i,j)]=;
}
}
}
if(i<m)
{
if(!map[i+][j]&&!map[i][j])
{
if((i+j)%)
graphic[Pos(i+,j)][Pos(i,j)]=;
if((i+j)%==)
graphic[Pos(i,j)][Pos(i+,j)]=;
}
}
}
}
int ans=n*m-k;
if(ans%==)
{
printf("NO\n");
continue;
}
int num=;
for(i=;i<=x;i++)
{
memset(vi,,sizeof(vi));
if(dfs(N[i]))
{
num++;
}
}
if(num*==ans)
printf("YES\n");
else
printf("NO\n"); }
return ;
}
poj 2446 二分图最大匹配的更多相关文章
- poj 2239 二分图最大匹配,基础题
1.poj 2239 Selecting Courses 二分图最大匹配问题 2.总结:看到一个题解,直接用三维数组做的,很巧妙,很暴力.. 题意:N种课,给出时间,每种课在星期几的第几节课上 ...
- POJ 2226二分图最大匹配
匈牙利算法是由匈牙利数学家Edmonds于1965年提出,因而得名.匈牙利算法是基于Hall定理中充分性证明的思想,它是二部图匹配最常见的算法,该算法的核心就是寻找增广路径,它是一种用增广路径求二分图 ...
- POJ Evacuation /// 二分图最大匹配
题目大意: 在一个n*m的房间中 ‘X’为墙 ‘D’为门 ‘.’为人 门只存在与外围 人每秒钟只能向四连通区域走一步 门比较狭窄 每秒钟只能通过一个人 求所有人逃脱的最短时间 如果不可能则输出impo ...
- poj 2724 二分图最大匹配
题意: 会给出M个串,我们要做的就是将这M个串给清除了.对于任意两个串,若二进制形式只有一位不一样,那么这两个串可以在一次操作消除,否则每个操作只能消除一个串. 3 3 *01 100 011 可以代 ...
- Asteroids - poj 3041(二分图最大匹配问题)
Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 17258 Accepted: 9386 Description Be ...
- poj 1469 二分图最大匹配
就是最简单的最大匹配,没的说 #include<iostream> #include<cstdio> #include<cstring> #include<a ...
- poj 1469(二分图 最大匹配)
这道题让我认识到了c++cin,cout确实会使其超时,还是我用的c printf吧 #include<cstdio> #include<iostream> #include& ...
- POJ 1719 二分图最大匹配(记录路径)
Shooting Contest Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 4097 Accepted: 1499 ...
- poj 3692 二分图最大匹配
思路: 如果我们将认识的建边,求最大独立集就是互相不认识的人数.那么我们反过来,将不认识的建图,求最大独立集就是互相认识的人数. #include<cstdio> #include< ...
随机推荐
- HDU 4901 The Romantic Hero (计数DP)
The Romantic Hero 题目链接: http://acm.hust.edu.cn/vjudge/contest/121349#problem/E Description There is ...
- 通过源码学Java基础:BufferedReader和BufferedWriter
准备写一系列Java基础文章,先拿Java.io下手,今天聊一聊BufferedReader和BufferedWriter BufferedReader BufferedReader继承Writer, ...
- [iOS UI进阶 - 0] Quiartz2D
A.简介 1. 需要掌握的 drawRect:方法的使用 常见图形的绘制:线条.多边形.圆 绘图状态的设置:文字颜色.线宽等 图形上下文状态的保存与恢复 图形上下文栈 1.基本图形绘制* 线段(线宽. ...
- UVaLive 6628 Grachten (水题,数学)
题意:给定一个平面图形并且且给了几条连,求一条. 析:简单么,三角形相似,很简单就AC. 代码如下: #pragma comment(linker, "/STACK:1024000000,1 ...
- eclipse 插件
eclipse 插件 pdt(http://projects.eclipse.org/projects/tools.pdt/downloads) PHP Development Tools 3.2 R ...
- TChromeTabs 优化改进
已知未解决问题 全屏时当窗体失去焦点,则会显示出未绘制完成的原标题栏(Fixed): 处于非 Areo 效果下时,窗体标题栏需要定制. 新增按钮上的 Hint 提示后再移至其它标签,将无法重新提示. ...
- 【转】python的小知识
1. 如何反序访问一个序列(how do I iterate over a sequence in reverse order) 如果序列是list,则使用list.reverse()即可将序列反序. ...
- 【M26】限制某个class所能产生的对象数量
1.每当产生一个对象,必定调用构造方法.因此,禁止产生对象的做法就是,将所有的构造方法声明为private. 2.只有在类的内部才可以访问private成员,有两层含义:在类的内部可以访问this的p ...
- VS DLL 复制本地
1.引用一个DLL,需要指定路径,复制本地的意思是 把这个DLL复制到exe的Debug目录(调试的时候). 2.复制到本地的动作是在生成的时候执行的,清理的时候会删除. 3.从外部引用一个DLL,不 ...
- cdoj 1250 喵哈哈的矩阵 数学题
喵哈哈的矩阵 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/1250 Desc ...