当前位置: 首页 > news >正文

[POJ2446] Chessboard(二分图最大匹配-匈牙利算法)

传送门

 

把所有非障碍的相邻格子彼此连一条边,然后求二分图最大匹配,看 tot * 2 + k 是否等于 n * m 即可。

但是连边不能重复,比如 a 格子 和 b 格子 相邻,不能 a 连 b ,b 也连 a。

所以可以人为规定,横纵坐标相加为 奇数 的格子连横纵坐标相加为 偶数 的格子。

如果一个格子横纵坐标相加为奇数,那么它的上下左右四个格子横纵坐标相加必定为偶数。

 

——代码

 1 #include <cstdio>
 2 #include <cstring>
 3 
 4 using namespace std;
 5 
 6 const int MAXN = 1001;
 7 int n, m, cnt, t, tot, k1, k2;
 8 int head[10001], to[10001], next[10001], belong[10001], map[MAXN][MAXN];
 9 int dx[4] = {0, 1, -1, 0},
10     dy[4] = {1, 0, 0, -1};
11 bool b[MAXN][MAXN], vis[10001];
12 
13 inline void add(int x, int y)
14 {
15     to[cnt] = y;
16     next[cnt] = head[x];
17     head[x] = cnt++;
18 }
19 
20 inline int find(int u)
21 {
22     int i, v;
23     for(i = head[u]; i != -1; i = next[i])
24     {
25         v = to[i];
26         if(!vis[v])
27         {
28             vis[v] = 1;
29             if(!belong[v] || find(belong[v]))
30             {
31                 belong[v] = u;
32                 return 1;
33             }
34         }
35     }
36     return 0;
37 }
38 
39 int main()
40 {
41     int i, j, k, x, y;
42     while(~scanf("%d %d %d", &n, &m, &t))
43     {
44         k1 = k2 = 0;
45         memset(head, -1, sizeof(head));
46         memset(belong, 0, sizeof(belong));
47         memset(b, 0, sizeof(b));
48         for(i = 1; i <= t; i++)
49         {
50             scanf("%d %d", &x, &y);
51             b[y - 1][x - 1] = 1;
52         }
53         for(i = 0; i < n; i++)
54             for(j = 0; j <= m; j++)
55             if(!b[i][j])
56                 if((i + j) % 2 == 1) map[i][j] = ++k1;
57                 else map[i][j] = ++k2;
58         for(i = 0; i < n; i++)
59             for(j = 0; j < m; j++)
60                 if(!b[i][j] && (i + j) % 2 == 1)
61                 for(k = 0; k <= 3; k++)
62                 {
63                     x = i + dx[k];
64                     y = j + dy[k];
65                     if(x >= 0 && x < n && y >= 0 && y < m && !b[x][y])
66                         add(map[i][j], map[x][y]);
67                 }
68         for(i = 1; i <= k1; i++)
69         {
70             memset(vis, 0, sizeof(vis));
71             if(find(i)) tot++;
72         }
73         if(2 * tot + t == n * m) printf("YES\n");
74         else printf("NO\n");
75     }
76     return 0;
77 }
View Code

 

转载于:https://www.cnblogs.com/zhenghaotian/p/6816108.html

相关文章:

  • java 多线程面试题
  • 第一阶段冲刺第七天
  • 【bzoj3831】[Poi2014]Little Bird 单调队列优化dp
  • [ABP实战开源项目]---ABP实时服务-通知系统.发布模式
  • bzoj4034: [HAOI2015]树上操作(树链剖分)
  • Leetcode 记录(1~100)
  • ArcGIS Server缓存清理
  • vmware和centos的安装
  • Vue.js中滚动条加载更多数据
  • 如何一键收藏微信文章?
  • 【Linux】【Services】【Project】Haproxy Keepalived Postfix实现邮件网关Cluster
  • 10.2.1 关于vc++不支持把类的成员函数定义为类的友元函数的处理
  • OC 手势可能出现的问题
  • Excel常用12个公式
  • Python web 框架:web.py
  • JavaScript 如何正确处理 Unicode 编码问题!
  • axios请求、和返回数据拦截,统一请求报错提示_012
  • centos安装java运行环境jdk+tomcat
  • javascript 哈希表
  • java多线程
  • LeetCode18.四数之和 JavaScript
  • Logstash 参考指南(目录)
  • Mac转Windows的拯救指南
  • Nodejs和JavaWeb协助开发
  • React-生命周期杂记
  • RxJS 实现摩斯密码(Morse) 【内附脑图】
  • scrapy学习之路4(itemloder的使用)
  • 欢迎参加第二届中国游戏开发者大会
  • 跨域
  • 人脸识别最新开发经验demo
  • 什么软件可以剪辑音乐?
  • 使用 QuickBI 搭建酷炫可视化分析
  • 使用阿里云发布分布式网站,开发时候应该注意什么?
  • 数据科学 第 3 章 11 字符串处理
  • 再谈express与koa的对比
  • 做一名精致的JavaScripter 01:JavaScript简介
  • hi-nginx-1.3.4编译安装
  • ​ 轻量应用服务器:亚马逊云科技打造全球领先的云计算解决方案
  • # Swust 12th acm 邀请赛# [ K ] 三角形判定 [题解]
  • #使用清华镜像源 安装/更新 指定版本tensorflow
  • (2)STL算法之元素计数
  • (4)事件处理——(2)在页面加载的时候执行任务(Performing tasks on page load)...
  • (二)fiber的基本认识
  • (附源码)ssm智慧社区管理系统 毕业设计 101635
  • (五)大数据实战——使用模板虚拟机实现hadoop集群虚拟机克隆及网络相关配置
  • (转)es进行聚合操作时提示Fielddata is disabled on text fields by default
  • (转)scrum常见工具列表
  • (转)全文检索技术学习(三)——Lucene支持中文分词
  • *p++,*(p++),*++p,(*p)++区别?
  • .halo勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .NET 2.0中新增的一些TryGet,TryParse等方法
  • .NET Core实战项目之CMS 第十二章 开发篇-Dapper封装CURD及仓储代码生成器实现
  • .net 获取url的方法
  • .NET/C# 使用反射调用含 ref 或 out 参数的方法
  • @Bean有哪些属性