2331: [SCOI2011]地板

Time Limit: 5 Sec  Memory Limit: 128 MB
Submit: 541  Solved: 239
[Submit][Status]

Description

lxhgww的小名叫“小L”,这是因为他总是很喜欢L型的东西。小L家的客厅是一个的矩形,现在他想用L型的地板来铺满整个客厅,客厅里有些位置有柱子,不能铺地板。现在小L想知道,用L型的地板铺满整个客厅有多少种不同的方案?

需要注意的是,如下图所示,L型地板的两端长度可以任意变化,但不能长度为0。铺设完成后,客厅里面所有没有柱子的地方都必须铺上地板,但同一个地方不能被铺多次。

Input

输入的第一行包含两个整数,R和C,表示客厅的大小。

接着是R行,每行C个字符。’_’表示对应的位置是空的,必须铺地板;’*’表示对应的位置有柱子,不能铺地板。

Output

输出一行,包含一个整数,表示铺满整个客厅的方案数。由于这个数可能很大,只需输出它除以20110520的余数。

Sample Input

2 2

*_

__

Sample Output

1

HINT

R*C<=100

  太久没做插头DP,一来就把R*C<=100看成R,C<=100,这道题主要问题还是在数据范围里面,交wa了一次,因为我默认R最大为10,而实际上R可以取到100.

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define MOD 20110520
#define MAXN 12
#define MAXV 531442
#define gv(x,ps) ((x)/p[(ps)]%3)
#define cd(x,ps) ((x)-((x)/p[ps]%3*p[ps]))
#define sd(x,ps,v) ((x)+v*p[ps])
int n,m;
void pm(int x)
{
int i;
for (i=;i<=m;i++)
{
printf("%d",x%);
x/=;
}
printf("\n");
}
void deal(int &x,int y)
{
x=(x+y)%MOD;
}
char mp[][];
int dp[][][MAXV];
int p[];
int main()
{
freopen("input.txt","r",stdin);
int i,j,k,x,y,z;
p[]=;
scanf("%d%d\n",&n,&m);
for (i=;i<;i++)
p[i]=p[i-]*;
for (i=;i<n;i++)
{
for (j=;j<m;j++)
{
scanf("%c",&mp[i][j]);
}
scanf("\n");
}
int l;
if (n<m)
{
for (i=;i<max(n,m);i++)
{
for (j=i+;j<max(n,m);j++)
{
swap(mp[i][j],mp[j][i]);
}
}
swap(n,m);
}
l=p[m+];
dp[][][]=;
int v;
for (i=;i<n;i++)
{
for (j=;j<m;j++)
{
if (j==m-)//{{{
{
if (mp[i][j]=='*')
{
for (k=;k<l;k++)
{
if (!dp[i&][j][k])continue;
x=gv(k,j);
y=gv(k,j+);
if (x||y)continue;
deal(dp[(i+)&][][k*],dp[i&][j][k]);
}
memset(dp[i&],,sizeof(dp[i&]));
}else
{
for (k=;k<l;k++)
{
if (!dp[i&][j][k])continue;
x=gv(k,j);
y=gv(k,j+);
v=cd(k,j);
v=cd(v,j+);
if (x== && y==)
{
z=sd(v,j,);
deal(dp[(i+)&][][z*],dp[i&][j][k]);
}else if (x== && y==)
{
z=sd(v,j,);
deal(dp[(i+)&][][z*],dp[i&][j][k]);
}else if (x== && y==)
{
z=sd(v,j,);
deal(dp[(i+)&][][z*],dp[i&][j][k]);
z=v;
deal(dp[(i+)&][][z*],dp[i&][j][k]);
}else if (x== && y==)
{
z=sd(v,j,);
deal(dp[(i+)&][][z*],dp[i&][j][k]);
}else if (x== && y==)
{
z=v;
deal(dp[(i+)&][][z*],dp[i&][j][k]);
}else if (x== && y==)
{
//DO nothing
}else if (x== && y==)
{
z=v;
deal(dp[(i+)&][][z*],dp[i&][j][k]);
}else if (x== && y==)
{
//Do nothing
}else if (x== && y==)
{
//Do nothing
}
}
memset(dp[i&],,sizeof(dp[i&]));
}
}else//}}}
{
if (mp[i][j]=='*')
{
for (k=;k<l;k++)
{
if (!dp[i&][j][k])continue;
x=gv(k,j);
y=gv(k,j+);
if (x||y)continue;
deal(dp[i&][j+][k],dp[i&][j][k]);
}
}else
{
for (k=;k<l;k++)
{
if (!dp[i&][j][k])continue;
x=gv(k,j);
y=gv(k,j+);
v=cd(k,j);
v=cd(v,j+);
if (x== && y==)
{
z=sd(v,j+,);
deal(dp[i&][j+][z],dp[i&][j][k]);
z=sd(v,j,);
deal(dp[i&][j+][z],dp[i&][j][k]);
z=sd(v,j+,);
z=sd(z,j,);
deal(dp[i&][j+][z],dp[i&][j][k]);
}else if (x== && y==)
{
z=sd(v,j+,);
deal(dp[i&][j+][z],dp[i&][j][k]);
z=sd(v,j,);
deal(dp[i&][j+][z],dp[i&][j][k]);
}else if (x== && y==)
{
z=v;
deal(dp[i&][j+][z],dp[i&][j][k]);
z=sd(v,j,);
deal(dp[i&][j+][z],dp[i&][j][k]);
}else if (x== && y==)
{
z=sd(v,j+,);
deal(dp[i&][j+][z],dp[i&][j][k]);
z=sd(v,j,);
deal(dp[i&][j+][z],dp[i&][j][k]);
}else if (x== && y==)
{
z=v;
deal(dp[i&][j+][z],dp[i&][j][k]);
}else if (x== && y==)
{
//Do nothing
}else if (x== && y==)
{
z=sd(v,j+,);
deal(dp[i&][j+][z],dp[i&][j][k]);
z=v;
deal(dp[i&][j+][z],dp[i&][j][k]);
}else if (x== && y==)
{
//Do nothing
}else if (x== && y==)
{
//Do nothing
}
}
}
}
}
}
cout<<dp[n&][][]<<endl;
return ;
}

bzoj 2331: [SCOI2011]地板 插头DP的更多相关文章

  1. BZOJ 2331 [SCOI2011]地板 ——插头DP

    [题目分析] 经典题目,插头DP. switch 套 switch 代码瞬间清爽了. [代码] #include <cstdio> #include <cstring> #in ...

  2. 【BZOJ】2331: [SCOI2011]地板 插头DP

    [题意]给定n*m的地板,有一些障碍格,要求用L型的方块不重不漏填满的方案数.L型方块是从一个方格向任意两个相邻方向延伸的方块,不能不延伸.n*m<=100. [算法]插头DP [题解]状态0表 ...

  3. 2331: [SCOI2011]地板 插头DP

    国际惯例的题面:十分显然的插头DP.由于R*C<=100,所以min(R,C)<=10,然后就可以愉悦地状压啦.我们用三进制状压,0表示没有插头,1表示有一个必须延伸至少一格且拐弯的插头, ...

  4. 【BZOJ2331】[SCOI2011]地板 插头DP

    [BZOJ2331][SCOI2011]地板 Description lxhgww的小名叫“小L”,这是因为他总是很喜欢L型的东西.小L家的客厅是一个的矩形,现在他想用L型的地板来铺满整个客厅,客厅里 ...

  5. bzoj:2331: [SCOI2011]地板

    Description lxhgww的小名叫“小L”,这是因为他总是很喜欢L型的东西.小L家的客厅是一个的矩形,现在他想用L型的地板来铺满整个客厅,客厅里有些位置有柱子,不能铺地板.现在小L想知道,用 ...

  6. bzoj 2331: [SCOI2011]地板【插头dp】

    一开始设计了四种状态,多了一种已经拐弯但是长度为0的情况,后来发现不用,设012表示没插头,没拐弯的插头,拐了弯的插头,然后转移的话12,21,22都不合法,剩下的转移脑补一下即可,ans只能在11, ...

  7. 【BZOJ】2331: [SCOI2011]地板

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2331 一眼插头DP... 考虑一个L形的东西,要构成它可以划分为两个阶段,即当前线段是拐了 ...

  8. [SCOI2011][bzoj2331] 地板 [插头dp]

    题面: 传送门 思路: 插头dp基础教程 这个L形......第一眼看上去真的是丧病啊 但是仔细想想,实际上也就是拿一堆路径铺满一个棋盘,这个路径还是有限制的 那还有什么好说的,插头dp上啊[雾] 首 ...

  9. BZOJ.1210.[HNOI2004]邮递员(插头DP Hash 高精)

    BZOJ 洛谷 http://www.cnblogs.com/LadyLex/p/7326874.html 插头DP.\(m+1\)个插头的状态需要用三进制表示:\(0\)表示无插头,\(1\)表示是 ...

随机推荐

  1. C# 创建新RTF文件

    这个和WINDOWS创建RTF文件一样 public void CreateRtfFile(string RtfFileName) { RichTextBox richTextBox1 = new R ...

  2. Tomcat配置gzip压缩

    HTTP 压缩能够大大提高浏览站点的速度,它的原理是,在client请求网 页后,从server端将网页文件压缩,再下载到client,由client的浏览器负责解 压缩并浏览.相对于普通的浏览过程H ...

  3. iOS中Git的使用

    打开终端: 查看Git的版本的终端命令:git —version 输入:ssh 查看是否已经存在ssh. 如果存在,先将已有的ssh备份,或者将新建的ssh生成到另外的目录下 如果不存在,通过默认的参 ...

  4. Objhdu2001java

    计算两点间的距离 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  5. Ⅰ.AngularJS的点点滴滴--引导

    AngularJS已经被很多人像炒冷饭一样炒过啦,大部分都是直接复制官方文档没有说明一些注意事项,不过什么都要从头开始吧 页面引导实例化 1.自动实例化 <html> <script ...

  6. value must be omitted for boolean attributes

    jsx文件中 html5一些标签的属性是boolean的,<div hidden="true">是不被允许的,要改成<div hidden>或<div ...

  7. 【Android】数据存储-SharedPreferences存储

    简单介绍:SharedPreferences是使用键值对的方式来存储数据的,也就是说,当保存一条数据的时候,给这条数据提供一个键,如果需要读取数据,只需要通过这个键就可以提取到对应的数据. 一:存储数 ...

  8. 关于json中对象的删除

    一个json对象在后台产生了,但是有些数据可能无效或者不合法,所以需要在前台作些例外处理,比如删除掉. json的删除有很多种,直接用过 delete json对象方式. 举例如下 Js代码 var ...

  9. mysql开启函数功能

    输入 show variables like '%func%'; 命令 会看到 log_bin_trust_function_creators 的状态,如果是OFF表示自定义函数功能是关闭的 输入命令 ...

  10. (转)Spring读书笔记-----Spring核心机制:依赖注入

    Java应用(从applets的小范围到全套n层服务端企业应用)是一种典型的依赖型应用,它就是由一些互相适当地协作的对象构成的.因此,我们说这些对象间存在依赖关系.加入A组件调用了B组件的方法,我们就 ...