poj 3133 Manhattan Wiring
http://poj.org/problem?id=3133
考虑插头 dp
用四进制表示一个插头的状态,0 表示没有插头,2 表示这个插头是连接两个 2 的,3 同理
然后就是大力分类讨论了
这题还是比较友善的一题,思路相对来说简单很多
我写的括号序列的方法状态是满的,数组必须开到 $ 3 ^ 9 $ 才能过
#include <cstdio>
#include <cstring>
#include <algorithm>
#define CIOS ios::sync_with_stdio(false);
#define rep(i, a, b) for(register int i = a; i <= b; i++)
#define per(i, a, b) for(register int i = a; i >= b; i--)
#define DEBUG(x) cerr << "DEBUG" << x << " >>> ";
using namespace std;
typedef unsigned long long ull;
typedef long long ll;
template <typename T>
inline void read(T &f) {
f = 0; T fu = 1; char c = getchar();
while(c < '0' || c > '9') { if(c == '-') fu = -1; c = getchar(); }
while(c >= '0' && c <= '9') { f = (f << 3) + (f << 1) + (c & 15); c = getchar(); }
f *= fu;
}
template <typename T>
void print(T x) {
if(x < 0) putchar('-'), x = -x;
if(x < 10) putchar(x + 48);
else print(x / 10), putchar(x % 10 + 48);
}
template <typename T>
void print(T x, char t) {
print(x); putchar(t);
}
const int mod = 19687, N = mod + 50, INF = 0x7fffffff;
int a[15][15], bin[15], f[2][N], v[2][N], head[N], tot[2], nxt[N], n, m, now;
// 状态只有 0, 2, 3, 表示没有插头, 2 插头和 3 插头
void ins(int zt, int val) {
int u = zt % mod;
for(register int i = head[u]; i; i = nxt[i])
if(v[now][i] == zt) {
f[now][i] = min(f[now][i], val);
return;
}
nxt[++tot[now]] = head[u]; head[u] = tot[now];
v[now][tot[now]] = zt; f[now][tot[now]] = val;
}
void sol() {
tot[now] = 1; f[now][1] = v[now][1] = 0;
for(register int i = 1; i <= n; i++) {
for(register int i = 1; i <= tot[now]; i++) v[now][i] <<= 2;
for(register int j = 1; j <= m; j++) {
now ^= 1; memset(head, 0, sizeof(head)); tot[now] = 0;
for(register int k = 1; k <= tot[now ^ 1]; k++) {
int zt = v[now ^ 1][k], val = f[now ^ 1][k];
int left = (zt >> ((j << 1) - 2)) & 3, up = (zt >> (j << 1)) & 3;
int right = (j == m) ? 1 : a[i][j + 1], down = (i == n) ? 1 : a[i + 1][j];
if(a[i][j] == 1) {
if(!left && !up) ins(zt, val);
} else if(!left && !up) {
if(!a[i][j]) {
ins(zt, val);
if(right + down == 5 || right == 1 || down == 1) continue;
if(right == 2 || down == 2) {
// 当两边有 2 插头时, 向下和向右摆 2 插头
ins(zt ^ (bin[j - 1] << 1) ^ (bin[j] << 1), val + 1);
} else if(right == 3 || down == 3) {
ins(zt ^ (bin[j - 1] * 3) ^ (bin[j] * 3), val + 1);
} else {
ins(zt ^ (bin[j - 1] << 1) ^ (bin[j] << 1), val + 1);
ins(zt ^ (bin[j - 1] * 3) ^ (bin[j] * 3), val + 1);
}
} else {
// 当前位置是一个 2 或 3
if(a[i][j] + right != 5 && right != 1) {
ins(zt ^ (bin[j] * a[i][j]), val + 1);
}
if(a[i][j] + down != 5 && down != 1) {
ins(zt ^ (bin[j - 1] * a[i][j]), val + 1);
}
}
} else if(left && up) {
if(left + up == 5 || a[i][j]) continue;
ins(zt ^ (bin[j - 1] * left) ^ (bin[j] * up), val + 1);
} else if(left && !up) {
if(a[i][j] == 0) {
if(right == 0 || right == left) ins(zt ^ (bin[j - 1] * left) ^ (bin[j] * left), val + 1);
if(down == 0 || down == left) ins(zt, val + 1);
} else if(a[i][j] == left) {
ins(zt ^ (bin[j - 1] * left), val + 1);
}
} else if(!left && up) {
if(a[i][j] == 0) {
if(right == 0 || right == up) ins(zt, val + 1);
if(down == 0 || down == up) ins(zt ^ (bin[j] * up) ^ (bin[j - 1] * up), val + 1);
} else if(a[i][j] == up) {
ins(zt ^ (bin[j] * up), val + 1);
}
}
}
}
}
}
int main() {
bin[0] = 1; for(register int i = 1; i <= 11; i++) bin[i] = bin[i - 1] << 2;
while(scanf("%d %d", &n, &m) == 2 && n && m) {
memset(a, 0, sizeof(a)); memset(head, 0, sizeof(head)); memset(tot, 0, sizeof(tot));
for(register int i = 1; i <= n; i++) {
for(register int j = 1; j <= m; j++) read(a[i][j]);
}
sol(); int ans = INF;
for(register int i = 1; i <= tot[now]; i++) ans = min(ans, f[now][i]);
if(ans == INF) ans = 2; print(ans - 2, '\n');
}
return 0;
}
poj 3133 Manhattan Wiring的更多相关文章
- POJ 3133 Manhattan Wiring (插头DP,轮廓线,经典)
题意:给一个n*m的矩阵,每个格子中有1个数,可能是0或2或3,出现2的格子数为2个,出现3的格子数为2个,要求将两个2相连,两个3相连,求不交叉的最短路(起终点只算0.5长,其他算1). 思路: 这 ...
- 【POJ】3133 Manhattan Wiring
http://poj.org/problem?id=3133 题意:n×m的网格,有2个2,2个3,他们不会重合.还有障碍1.现在求2到2的路径和3到3的路径互不相交的最短长度-2.(2<=n, ...
- poj3133 Manhattan Wiring
Manhattan Wiring Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 2016 Accepted: 1162 ...
- [LA3620]Manhattan Wiring
[LA3620]Manhattan Wiring 试题描述 输入 输出 输入示例 输出示例 数据规模及约定 见“输入” 题解 我们把“连线”的过程改为“铺地砖”的过程,总共有 11 种地砖,每种地砖上 ...
- 【poj3133】 Manhattan Wiring
http://poj.org/problem?id=3133 (题目链接) 题意 $n*m$的网格里有空格和障碍,还有两个$2$和两个$3$.要求把这两个$2$和两个$3$各用一条折线连起来.障碍里不 ...
- poj 1806 Manhattan 2025
点击打开链接 题目大意就是给定一个最大歩数,让你输出你在三维的空间中可以到达的位置的切片,注意当歩数大于9的时候就不需要输出了! #include<stdio.h> #include< ...
- uva1214 Manhattan Wiring 插头DP
There is a rectangular area containing n × m cells. Two cells are marked with “2”, and another two w ...
- [Poj3133]Manhattan Wiring (插头DP)
Description 题目大意:给你个N x M(1≤N, M≤9)的矩阵,0表示空地,1表示墙壁,2和3表示两对关键点.现在要求在两对关键点之间建立两条路径,其中两条路径不可相交或者自交(就是重复 ...
- caioj1496: [视频]基于连通性状态压缩的动态规划问题:Manhattan Wiring
%%%%orz苏大佬 虽然苏大佬的baff吸不得,苏大佬的梦信不得,但是膜苏大佬是少不得的囧 这题还是比较有收获的 哼居然有我不会做的插头DP 自己yy了下,2表示属于2的插头,3表示3的插头 假如当 ...
随机推荐
- js字符转换为数字
转换函数.强制类型转换.利用js变量弱类型转换. 1. 转换函数: js提供了parseInt()和parseFloat()两个转换函数.前者把值转换成整数,后者把值转换成浮点数.只有对String类 ...
- Cloudera Manger CDH 安装文档
简介: Cloudera Manager 是 Cloudera 公司推出的 Hadoop 集群管理工具,通过该管理工具可以方便的部署.配置.监控集群. Cloudera 公司自己发布的 Hadoop ...
- 数据挖掘模型中的IV和WOE详解
IV: 某个特征中 某个小分组的 响应比例与未响应比例之差 乘以 响应比例与未响应比例的比值取对数 数据挖掘模型中的IV和WOE详解 http://blog.csdn.net/kevin7658/ar ...
- Apt-Cacher-ng 搭建缓存服务器
docker pull minimum2scp/apt-cacher-ng docker run -d -p 3142:3142 --name=cache -e ACNG_BACKENDS_DEBIA ...
- 关于网页头图标ico的问题
今天同事问了我一个比较奇怪的问题,对于我来说,可能和编码没什么关系,但是确实是头一次注意到,所以把问题记录了下来,方便以后积累经验. 问题就是: 在本地的网页中设置了头图标 <link rel= ...
- js输出/获得Cookie
js输出/获得Cookie //方法 1 function setCookie(name, value) { var Days = 365; var exp = new Date(); exp.set ...
- Golang之字符串操作(反转中英文字符串)
//字符串反转package main import "fmt" func reverse(str string) string { var result string strLe ...
- 逆序对 分治nlogn
定义:A是包含n个元素的有序序列{a1,a2 … an},若ai > aj 且 i < j ,则称 (ai , aj)是A的一个逆序对.求逆序对是指求出A中存在逆序对的数量. 这个算法是归 ...
- [模板]LIS(最长上升子序列)
转载自:最长上升子序列(LIS)长度的O(nlogn)算法 最长上升子序列nlogn算法 在川大oj上遇到一道题无法用n^2过于是,各种纠结,最后习得nlogn的算法 最长递增子序列,Longest ...
- labview使用场景
测试测量:LABVIEW [6] 最初就是为测试测量而设计的,因而测试测量也就是现在LABVIEW最广泛的应用领域.经过多年的发展,LABVIEW在测试测量领域获得了广泛的承认.至今,大多数主流的测 ...