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

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=105,mod=20110520,has=739391;
int n,m,a[N][N],b[N],h[1000005],c[2],nw,la,tx,ty,ans;
char s[N];
struct qwe
{
int ne,to[2],va[2];
}f[1000005];
void jia(int &x,int y)
{
x+=y;
x>=mod?x-=mod:0;
}
void add(int x,int v)
{
int u=x%has+1;
for(int i=h[u];i;i=f[i].ne)
if(f[i].to[nw]==x)
{
jia(f[i].va[nw],v);
return;
}
c[nw]++;
f[c[nw]].ne=h[u];
f[c[nw]].to[nw]=x;
f[c[nw]].va[nw]=v;
h[u]=c[nw];
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
{
scanf("%s",s+1);
for(int j=1;j<=m;j++)
if(s[j]=='_')
{
if(n>m)
a[i][j]=1;
else
a[j][i]=1;
}
}
if(n<m)
swap(n,m);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
if(a[i][j])
tx=i,ty=j;
b[0]=1;
for(int i=1;i<=20;i++)
b[i]=(b[i-1]<<2);
c[0]=1,f[1].va[0]=1,f[1].to[0]=0;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=c[nw];j++)
f[j].to[nw]<<=2;
for(int j=1;j<=m;j++)
{
memset(h,0,sizeof(h));
la=nw,nw^=1;
c[nw]=0;
for(int k=1;k<=c[la];k++)
{
int x=f[k].to[la],b1=(x>>(j*2-2))%4,b2=(x>>(j*2))%4,v=f[k].va[la];
if(!a[i][j])
{
if(b1==0&&b2==0)
add(x,v);
}
else if(b1==0&&b2==0)
{
if(a[i+1][j]&&a[i][j+1])
add(x+2*b[j-1]+2*b[j],v);
if(a[i+1][j])
add(x+b[j-1],v);
if(a[i][j+1])
add(x+b[j],v);
}
else if(b1==0&&b2==1)
{
if(a[i][j+1])
add(x+b[j],v);
if(a[i+1][j])
add(x+b[j-1]-b[j],v);
}
else if(b1==0&&b2==2)
{
if(i==tx&&j==ty)
jia(ans,v);
add(x-2*b[j],v);
if(a[i+1][j])
add(x+2*b[j-1]-2*b[j],v);
}
else if(b1==1&&b2==0)
{
if(a[i+1][j])
add(x+b[j-1],v);
if(a[i][j+1])
add(x-b[j-1]+b[j],v);
}
else if(b1==1&&b2==1)
{
if(i==tx&&j==ty)
jia(ans,v);
add(x-b[j-1]-b[j],v);
}
else if(b1==2&&b2==0)
{
if(i==tx&&j==ty)
jia(ans,v);
add(x-2*b[j-1],v);
if(a[i][j+1])
add(x-2*b[j-1]+2*b[j],v);
}
}
}
}
printf("%d\n",ans);
return 0;
}

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

  1. bzoj 2331: [SCOI2011]地板 插头DP

    2331: [SCOI2011]地板 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 541  Solved: 239[Submit][Status] D ...

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

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

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

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

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

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

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

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

  6. bzoj:2331: [SCOI2011]地板

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

  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. 怎样去除JSP页面提示:Cannot return from outside a function or method.

     今天用myeclipse10写JSP页面时出现: Cannot return from outside a function or method. onClick="return ch ...

  2. 线程特定数据TSD总结

    一线程的本质 二线程模型的引入 三线程特定数据 四关键函数说明 五刨根问底啥原理 六私有数据使用演示样例 七參考文档 一.线程的本质 Linux线程又称轻量进程(LWP),也就说线程本质是用进程之间共 ...

  3. bsp开发之驱动开发

    驱动程序是可以管理虚拟设备或者物理设备,协议,服务等得软件模块,操作系统仅仅有通过驱动程序才干訪问硬件.针对windows ce开发设备驱动.就是通过platform builder创建一个新的平台, ...

  4. C#语言基础语句

    case,switch,break的使用 Console.WriteLine("1.汉堡"); Console.WriteLine("2.薯条"); Conso ...

  5. 使用 C# 开发智能手机软件:推箱子(四)

    这是"使用 C# 开发智能手机软件:推箱子"系列文章的第四篇. 在这篇文章中,介绍 Common/FindPath.cs 源程序文件. using System; using Sy ...

  6. 【读书笔记】iOS-GCD-用法

    代码: -(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event { dispatch_async(dispatch_get_gl ...

  7. 苹果应用内支付(iOS IAP)的流程与常用攻击方式

    1. 客户端直接verify苹果的receipt 如果verify成功 自行发放商品 2. 客户端将receipt传给server,由server进行验证并发放商品 按照安全性原则, 客户端的所有信息 ...

  8. 使用JavaScript获取浏览器Chrome版本信息

    Navigator对象包含了有关浏览器的信息 可通过访问其属性appVersion或userAgent来获取浏览器Chrome版本 例如,我所使用的QQ浏览器的appVersion和userAgent ...

  9. SLG, 菱形格子的算法.(递归版

    class GeoPoint{ public: int x; int y; public: bool operator == (const GeoPoint& p){ return p.x = ...

  10. python 将屏幕输出定向到变量中

    #!/usr/bin/python # -*- coding: utf-8 -*- import sys import subprocess as sp def main(): cmd = 'syst ...