SGU 131.Hardwood floor
时间限制:0.25s
空间限制:4M
题意:
给出 n*m (1≤n、m≤9)的方格棋盘,用 1*2 的矩形的骨牌和 L 形的(2*2 的
去掉一个角)骨牌不重叠地覆盖,求覆盖满的方案数。
Solution:
还是状态压缩,这次的情况比较多,要全部列出。
b1,b2分别代表上下两行前列对下一列的影响
s1,s2对应上下两行的状态
|
情况 |
上列b1,b2要求 |
状态改变 | 对下一列的影响 |
|
10 10 |
b1=0, b2=0; |
s1<<1, s2<<1|1; |
b1=0, b2=0; |
|
11 10 |
b1=0, b2=0; |
s1<<1, s2<<1|1; |
b1=1, b2=0; |
|
10 11 |
b1=0, b2=0; |
s1<<1, s2<<1|1; |
b1=0, b2=1; |
|
00 11 |
b2=0; |
s1<<1|1-b1, s2<<1|1; |
b1=0, b2=1; |
|
01 11 |
b2=0; |
s1<<1|1-b1, s2<<1|1; |
b1=1, b2=1; |
|
11 01 |
b1=0; |
s1<<1, s2<<1|b2; |
b1=1, b2=1; |
|
00 00 |
无 |
s1<<1|1-b1, s2<<1|b2; |
b1=0, b2=0; |
参考代码:
#include <iostream>
#include <cstdio>
#define LL long long
using namespace std;
int n, m, x;
LL f[12][1 << 12];
//b1,b2,分别标记上一列队下一列的影响
void dfs (int k, int last, int now, int b1, int b2) {
if (k == m){
if(!b1&&!b2)
f[x][now] += f[x - 1][last];
return;
}
if (!b1 && !b2) {
dfs (k + 1, last << 1 , now << 1 | 1, 0, 0);
dfs (k + 1, last << 1 , now << 1 | 1, 1, 0);
dfs (k + 1, last << 1 , now << 1 | 1, 0, 1);
}
if (!b1)
dfs (k + 1, last << 1 , now << 1 | b2, 1, 1);
if (!b2) {
dfs (k + 1, last << 1 | (1-b1), now << 1 | 1, 0, 1);
dfs (k + 1, last << 1 | (1-b1), now << 1 | 1, 1, 1);
}
dfs (k + 1, last << 1 | (1-b1), now << 1 | b2, 0, 0);
}
int main() {
scanf ("%d %d", &n, &m);
if (n < m) swap (n, m);
f[0][ (1 << m) - 1] = 1;
for ( x = 1; x <= n; x++)
dfs (0, 0, 0, 0, 0);
printf ("%lld", f[n][ (1 << m) - 1]);
}
SGU 131.Hardwood floor的更多相关文章
- SGU 131. Hardwood floor 状压dp 难度:2
131. Hardwood floor time limit per test: 0.25 sec. memory limit per test: 4096 KB The banquet hall o ...
- Hardwood floor - SGU 131(状态压缩)
题目大意:用 2*1 或者2*2-1的格子覆盖M*N的矩阵,有多少种覆盖方式. 分析:容易知道有以下6种放置方式. 然后用深搜的方法直接搞出来就行了,不过要使用两个变量来判断本位是否受影响.如果本行的 ...
- sgu 131 状压DP
棋盘覆盖(二) 时间限制:1000 ms | 内存限制:65535 KB 描述 The banquet hall of Computer Scientists' Palace has a ...
- SGU131 - Hardwood floor(状态压缩DP)
题目大意 给定一个N*M大小的矩形,要求你用1*2和2*2(缺个角)的砖块把矩形铺满(不能重叠),问总共有多少种铺法? 题解 受POJ2411的影响,怎么都没想到3,4,5,6这几种情况该怎么放置,看 ...
- SGU 分类
http://acm.sgu.ru/problemset.php?contest=0&volume=1 101 Domino 欧拉路 102 Coprime 枚举/数学方法 103 Traff ...
- 今日SGU 5.15
最近事情好多,数据库作业,没天要学2个小时java,所以更新的sgu就比较少了 SGU 131 题意:给你两种小块一种,1*1,一种2*2-1*1,问你填满一个m*n的矩形有多少钟方法,n和m小于等于 ...
- 今日SGU 5.14
//SGU 131 还没完全想清楚 留坑 SGU 259 题意:一个机器处理n个任务,每个任务有时间t和传送时间l 收获:贪心 #include<bits/stdc++.h> #defin ...
- 别人整理的DP大全(转)
动态规划 动态规划 容易: , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ...
- dp题目列表
此文转载别人,希望自己能够做完这些题目! 1.POJ动态规划题目列表 容易:1018, 1050, 1083, 1088, 1125, 1143, 1157, 1163, 1178, 1179, 11 ...
随机推荐
- vs2008 提示msdbg.dll未正确安装的解决办法
开始-->运行-->输入: regsvr32.exe "%ProgramFiles(x86)%\Common Files\Microsoft Shared\VS7Debug\ms ...
- activity跳转关闭软件盘
之前试过 if(getWindow().getAttributes().softInputMode==WindowManager.LayoutParams.SOFT_INPUT_STATE_UNSPE ...
- C#调用Web Service时的身份验证
原理:webservice所在的系统中,在系统域中建立用于登录的软件的用户和密码,软件登录时将用户名.密码和登录的本机的域的名字通过webService的NetworkCredential传递到web ...
- ZOJ- 3640 Help Me Escape
Help Me Escape Time Limit: 2 Seconds Memory Limit: 32768 KB Background If thou doest well, ...
- 汇编学习笔记(14)BIOS对键盘输入的处理
字符的处理 键盘输入的字符一般由int9中断例程从60h端口中读取,并存放在键盘缓冲区中,由int16h例程从键盘缓冲区中读取相应字符,CPU对键盘输入a.shift_a的处理过程如下 1.一开始没有 ...
- Unity Kajiya Hair Shader Mod by Normals
Shader "HairShader" { Properties { _MainTex ("Diffuse (RGB) Alpha (A)", 2D) = &q ...
- JavaScript高级程序设计12.pdf
第六章 面向对象的程序设计 ECMA中有两种属性:数据属性和访问器属性 数据属性的特性 [[Configurable]] 表示是否通过delete删除属性,是否重新定义属性,是否能把属性修改为访问器属 ...
- Google表格
本博文的主要内容有 .Google表格的介绍 https://www.google.com/intl/zh-CN/sheets/about/ https://accounts.google.com/ ...
- [置顶] [MATLAB技术贴]漫谈MATLAB矩阵转置
矩阵转置是matlab最基本的操作了,但这个基本操作,也是很多初学者容易出现问题的地方.本帖通过几个实例演示matlab矩阵转置的操作. 方法一:' 运算符与 .' 运算符 >>a ...
- bzoj4447 SCOI2015 小凸解密码 password
传送门:bzoj4447 题解: 调试简直恶心,不过调完发现其实还是挺好写的. 用\(\mathrm{set}\)维护一段\(0\)区间的左右端点,每次最多修改两个点,所以很好维护. 查询的时候在\( ...