Description

A square township has been divided up into n*m(n rows and m columns) square plots (1<=N,M<=8),some of them are blocked, others are unblocked. The Farm is located in the lower left plot and the Market is located in the lower right plot. Tony takes her tour of the township going from Farm to Market by walking through every unblocked plot exactly once. 
Write a program that will count how many unique tours Betsy can take in going from Farm to Market. 

Input

The input contains several test cases. The first line of each test case contain two integer numbers n,m, denoting the number of rows and columns of the farm. The following n lines each contains m characters, describe the farm. A '#' means a blocked square, a '.' means a unblocked square. 
The last test case is followed by two zeros. 

Output

For each test case output the answer on a single line.
 
题目大意:找到一条路径,经过所有非阻塞点,从右下到达左下。
思路:在最后加两排
.#######.
.......
 
代码(16MS):
 #include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
typedef long long LL; const int MAXN = ;
const int SIZEH = ;
const int MAXH = ; struct hash_map {
int head[SIZEH], size;
int state[MAXH], next[MAXH];
LL val[MAXH]; void init() {
memset(head, -, sizeof(head));
size = ;
} void insert(int st, LL sv) {
int h = st % SIZEH;
for(int p = head[h]; ~p; p = next[p]) {
if(state[p] == st) {
val[p] += sv;
return ;
}
}
state[size] = st; val[size] = sv; next[size] = head[h]; head[h] = size++;
}
} hashmap[]; hash_map *cur, *last;
int acc[] = {, -, , };
char mat[MAXN][MAXN];
int n, m, en, em; int getB(int state, int i) {
return (state >> (i << )) & ;
} void setB(int &state, int i, int val) {
state = (state & ~( << (i << ))) | (val << (i << ));
} int getLB(int state, int i) {
int ret = i, cnt = ;
while(cnt) {
--ret;
cnt += acc[getB(state, ret)];
}
return ret;
} int getRB(int state, int i) {
int ret = i, cnt = -;
while(cnt) {
++ret;
cnt += acc[getB(state, ret)];
}
return ret;
} void update(int x, int y, int state, LL tv) {
int left = getB(state, y);
int up = getB(state, y + );
if(mat[x][y] == '#') {
if(left == && up == ) cur->insert(state, tv);
return ;
}
if(left == && up == ) {
if(x == n - || y == m - ) return ;
int newState = state;
setB(newState, y, );
setB(newState, y + , );
cur->insert(newState, tv);
} else if(left == || up == ) {
if(x < n - ) {
int newState = state;
setB(newState, y, up + left);
setB(newState, y + , );
cur->insert(newState, tv);
}
if(y < m - ) {
int newState = state;
setB(newState, y, );
setB(newState, y + , up + left);
cur->insert(newState, tv);
}
} else {
int newState = state;
setB(newState, y, );
setB(newState, y + , );
if(left == && up == ) setB(newState, getRB(state, y + ), );
if(left == && up == && !(x == en && y == em)) return ;
if(left == && up == ) setB(newState, getLB(state, y), );
cur->insert(newState, tv);
}
} void findend() {
for(en = n - ; en >= ; --en)
for(em = m - ; em >= ; --em) if(mat[en][em] != '#') return ;
} LL solve() {
findend();
cur = hashmap, last = hashmap + ;
last->init();
last->insert(, );
for(int i = ; i < n; ++i) {
int sz = last->size;
for(int k = ; k < sz; ++k) last->state[k] <<= ;
for(int j = ; j < m; ++j) {
cur->init();
sz = last->size;
for(int k = ; k < sz; ++k)
update(i, j, last->state[k], last->val[k]);
swap(cur, last);
}
}
for(int k = ; k < last->size; ++k)
if(last->state[k] == ) return last->val[k];
return ;
} int main() {
while(scanf("%d%d", &n, &m) != EOF) {
if(n == && m == ) break;
memset(mat, , sizeof(mat));
for(int i = ; i < n; ++i) scanf("%s", mat[i]);
for(int i = ; i < m - ; ++i) mat[n][i] = '#';
n += ;
cout<<solve()<<endl;
}
}

最新文章

  1. PHP 数组浅析
  2. 数据库操作提示:Specified key was too long; max key length is 767 bytes
  3. 在CentOS上搭建apache和PHP服务器环境(转)
  4. JavaScript 闯关记
  5. URL与图像格式
  6. 牛人总结python中string模块各属性以及函数的用法,果断转了,好东西
  7. C++ Primer笔记4_静态成员类_IO库
  8. centos7看电影
  9. R formulas in Spark and un-nesting data in SparklyR: Nice and handy!
  10. 通过pycharm的Database设置进行数据库的可视化
  11. 多个yml文件的读取方式
  12. hdu5306 Explosion
  13. TCP/IP详解 卷1 第一章概述
  14. CentOS 7 设置静态IP
  15. topcoder srm 715 div1 -23
  16. C# 编码标准(三)
  17. LeetCode: Distinct Subsequences 解题报告
  18. java copy 文件夹
  19. page 分页
  20. dddddddddddddddddd

热门文章

  1. Filebeat使用模块收集日志
  2. MySQL---正确使用索引、limit分页、执行计划、慢日志查询
  3. Web移动端商城 移动端商城手机网站html整套模板,web移动商城仿app手机模板下载
  4. golang区块链开发的视频教程推荐
  5. 优龙FS2410开发板学习过程遇到问题总结
  6. UNIX故障--sun m4000服务器故障硬盘更换案例
  7. 通过c#操作word文档的其他方式
  8. 北京Uber司机7月13日奖励政策更新
  9. C#防止程序重新运行
  10. Redis系列七 主从复制(Master/Slave)