bzoj 2331: [SCOI2011]地板 插头DP
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
*_
__
Sample Output
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的更多相关文章
- BZOJ 2331 [SCOI2011]地板 ——插头DP
[题目分析] 经典题目,插头DP. switch 套 switch 代码瞬间清爽了. [代码] #include <cstdio> #include <cstring> #in ...
- 【BZOJ】2331: [SCOI2011]地板 插头DP
[题意]给定n*m的地板,有一些障碍格,要求用L型的方块不重不漏填满的方案数.L型方块是从一个方格向任意两个相邻方向延伸的方块,不能不延伸.n*m<=100. [算法]插头DP [题解]状态0表 ...
- 2331: [SCOI2011]地板 插头DP
国际惯例的题面:十分显然的插头DP.由于R*C<=100,所以min(R,C)<=10,然后就可以愉悦地状压啦.我们用三进制状压,0表示没有插头,1表示有一个必须延伸至少一格且拐弯的插头, ...
- 【BZOJ2331】[SCOI2011]地板 插头DP
[BZOJ2331][SCOI2011]地板 Description lxhgww的小名叫“小L”,这是因为他总是很喜欢L型的东西.小L家的客厅是一个的矩形,现在他想用L型的地板来铺满整个客厅,客厅里 ...
- bzoj:2331: [SCOI2011]地板
Description lxhgww的小名叫“小L”,这是因为他总是很喜欢L型的东西.小L家的客厅是一个的矩形,现在他想用L型的地板来铺满整个客厅,客厅里有些位置有柱子,不能铺地板.现在小L想知道,用 ...
- bzoj 2331: [SCOI2011]地板【插头dp】
一开始设计了四种状态,多了一种已经拐弯但是长度为0的情况,后来发现不用,设012表示没插头,没拐弯的插头,拐了弯的插头,然后转移的话12,21,22都不合法,剩下的转移脑补一下即可,ans只能在11, ...
- 【BZOJ】2331: [SCOI2011]地板
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2331 一眼插头DP... 考虑一个L形的东西,要构成它可以划分为两个阶段,即当前线段是拐了 ...
- [SCOI2011][bzoj2331] 地板 [插头dp]
题面: 传送门 思路: 插头dp基础教程 这个L形......第一眼看上去真的是丧病啊 但是仔细想想,实际上也就是拿一堆路径铺满一个棋盘,这个路径还是有限制的 那还有什么好说的,插头dp上啊[雾] 首 ...
- BZOJ.1210.[HNOI2004]邮递员(插头DP Hash 高精)
BZOJ 洛谷 http://www.cnblogs.com/LadyLex/p/7326874.html 插头DP.\(m+1\)个插头的状态需要用三进制表示:\(0\)表示无插头,\(1\)表示是 ...
随机推荐
- Java GC 概念摘要
很长时间,我想Java的GC做一个小小的总结,他有没有时间.根据最近看了java paper向上java gc文章,我觉得好,读读.顺便说一下,总结下. java paper的GC文章地址,里面有非常 ...
- Swift 析构器deinit
析构器只适用于类类型,当一个类的实例被释放之前,析构器会被立即调用.析构器用关键字deinit来标识,类似于构造器用init来标识. 原理: Swift会自动释放不再需要的实例以释放资源.Swift通 ...
- android 67 生成和解析xml
生成xml: package com.itheima.createxml; import java.io.File; import java.io.FileNotFoundException; imp ...
- RFC 文档(中文与英文)
http://man.chinaunix.net/develop/rfc/default.htm https://www.rfc-editor.org/retrieve/ http://www.iet ...
- RedHat7配置Nginx实现多域名虚拟主机的SSL/TLS认证(实现单IP以不同证书服务于不同域名)
以RedHat7(64bit)平台为例 如果RedHat源没法用,可以使用EPEL源 # rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-rel ...
- 如何通过PS制作图片文字效果
如图这是最终效果,下面我为大家介绍如何制作这种图片文字效果 准备一张图: 方法,步骤: 首先我们打开PHOTOSHOP,插入一张图片. 之后按键盘上面的"T"键快捷键启用文字工具, ...
- Windows Socket五种I/O模型
转载:http://www.cnblogs.com/tianzhiliang/archive/2010/08/31/1813637.html 如果你想在Windows平台上构建服务器应用,那么I/O模 ...
- CI笔记6 json 传值
CI3.x 使用json,配合easyui, 其实很简单,走了很多的弯路, 首先在ci的控制器重,建立2个方法,一个用于显示加载view,一个用于echo json,就可以了. 需要注意的是,在ci的 ...
- 数据库(学习整理)----3--Oracle创建表和设置约束
BBS论坛表设计 包含的表:BBSusers(用户表),BBSsection(版块表),BBStopic(主贴表),BBSreply(跟帖表) 表结构 1)BBSusers 字段名 字段说明 数据类型 ...
- canvas之----浮动小球
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...