时间限制:0.25s

空间限制:4M

题意:

给定一个N*N的棋盘,一些格子被移除,在棋盘上放置一些1*2的骨牌,判定能否放满,并且输出任意方案。


Solution:

首先考虑对棋盘的一个格子黑白染色(实际上不需要),得到一个类似国际象棋棋盘的东西,一个骨牌能放置在相邻的一对黑白格子上

我们考虑对每一个黑格子,连一条到相邻白色格子的边,然后做二分图的最大匹配,判断是否是完备匹配,输出解即可。

    思路比较简单直接,输出需要一些简单技巧和小处理。

code

#include <iostream>
#include <cstring>
#include <fstream>
#include <cmath>
#include <cstdio>
using namespace std;
const int INF = ;
struct node {
int u, v, next;
} edge[];
int pHead[INF], vis[INF], pr[INF];
int dx[] = {, , , -}, dy[] = {, -, , };
int n, m, x, y, nCnt, an;
int exPath (int x) {
for (int k = pHead[x]; k != ; k = edge[k].next) {
int x = edge[k].u, y = edge[k].v;
if (!vis[y]) {
vis[y] = ;
if ( !pr[y] || exPath (pr[y]) ) return pr[y] = x;
}
}
return ;
}
void addEdge (int u, int v) {
edge[++nCnt].u = u, edge[nCnt].v = v;
edge[nCnt].next = pHead[u];
pHead[u] = nCnt;
}
int g[][];
int main() {
//ofstream cout("out.txt");
cin >> n >> m;
for (int i = ; i <= n; i++)
for (int j = ; j <= n; j++) g[i][j] = ;
for (int i = ; i <= m; i++) {
cin >> x >> y;
g[x][y] = ;
}
for (int i = ; i <= n; i++)
for (int j = ; j <= n; j++) {
if (g[i][j])
for (int k = ; k < ; k++) {
int x = i + dx[k], y = j + dy[k];
if (g[x][y])
addEdge ( (i - ) *n + j, (x - ) *n + y);
}
}
for (int i = ; i <= n * n; i++) {
if (exPath (i) ) an++;
memset (vis, , sizeof vis);
}
int t1 = , t2 = ;
int ans[][INF];
for (int i = ; i <= n * n; i++) {
if (pr[i] && !vis[i]) {
vis[i] = vis[pr[i]] = ;
if (abs (pr[i] - i) == n)
ans[][++t1] = min (i, pr[i]);
else
ans[][++t2] = min (i, pr[i]);
}
}
if (an == (n * n - m) ) {
cout << "Yes" << endl;
cout << t1 << endl;
for (int i = ; i <= t1; i++) {
int l, r;
if (ans[][i] % n) l = ans[][i] / n + , r = ans[][i] % n;
else
l = ans[][i] / n, r = n;
cout << l << ' ' << r << endl;
}
cout << t2 << endl;
for (int i = ; i <= t2; i++) {
int l, r;
l = ans[][i] / n + , r = ans[][i] % n;
cout << l << ' ' << r << endl;
}
}
else
cout << "No";
return ;
}

最新文章

  1. (转)testng对失败时截图处理
  2. pagePiling.js - 创建漂亮的全屏滚动效果
  3. android 九宫加密记事本
  4. Java静态代码分析工具——FindBugs插件的安装与使用
  5. 将具有关联关系的两个表从hibernate查询出来转成json对象时报错
  6. catkin_make broken after intalling python 3.5 with anaconda
  7. Android中的文件权限操作
  8. 虚函数(virtual)为啥不能是static
  9. 写文件前, 检查目录写权限(PHP)
  10. C语言-04函数
  11. 构建自己的PHP框架--构建模版引擎(2)
  12. jdk动态代理举例
  13. 勤拂拭软件系列教程 - java web开发
  14. java反射机制,以及对反射机制的了解,如有差池欢迎点评(初学者勿喷)
  15. mybatis-generator 自动生成查询Vo
  16. Android 数据库 大量插入 事务开启
  17. Linux - 更改软件源
  18. UVa 1572 Self-Assembly (构造+拓扑排序。。。。。)
  19. jQuery碎语(1) 基础、选择要操作的元素、处理DOM元素
  20. 摘:VC开发数据库基础之ADO篇

热门文章

  1. Light OJ 1031 - Easy Game(区间DP)
  2. 【转】如图,win7登陆界面,键盘失灵,没办法登陆。求解!如何在这个界面打开个鼠标可以点的软键盘
  3. 从PowerDesigner概念设计模型(CDM)中的3种实体关系说起
  4. Lowest Common Ancestor of a Binary Tree——Leetcode
  5. Linux学习笔记25——命名管道(FIFO)
  6. JavaScript高级程序设计5.pdf
  7. [转]让程序在崩溃时体面的退出之Dump文件
  8. zabbix2.2.3 VMware Vsphere exsi监控配置步骤
  9. 通过例子学python(2.2)
  10. (配置)CKEditor+CKFinder+php上传配置,根据年月命名创建文件夹来存放