当前位置:网站首页>状态压缩dp蒙德里安的梦想
状态压缩dp蒙德里安的梦想
2022-08-10 18:23:00 【一条小小yu】
求把 N×MN×M 的棋盘分割成若干个 1×21×2 的长方形,有多少种方案。
例如当 N=2,M=4N=2,M=4 时,共有 55 种方案。当 N=2,M=3N=2,M=3 时,共有 33 种方案。
如下图所示:
输入格式
输入包含多组测试用例。
每组测试用例占一行,包含两个整数 NN 和 MM。
当输入用例 N=0,M=0N=0,M=0 时,表示输入终止,且该用例无需处理。
输出格式
每个测试用例输出一个结果,每个结果占一行。
数据范围
1≤N,M≤111≤N,M≤11
输入样例:
1 2 1 3 1 4 2 2 2 3 2 4 2 11 4 11 0 0
输出样例:
1 0 1 2 3 5 144 51205
#include<bits/stdc++.h>
using namespace std;
const int N = 12, M = 1 << N;
int st[M];
long long f[N][M];
int main(){
int n, m;
while (cin >> n >> m && (n || m)){
for (int i = 0; i < 1 << n; i ++){
int cnt = 0;
st[i] = true;
for (int j = 0; j < n; j ++)
if (i >> j & 1){
if (cnt & 1) st[i] = false; // cnt 为当前已经存在多少个连续的0
cnt = 0;
}
else cnt ++;
if (cnt & 1) st[i] = false; // 扫完后要判断一下最后一段有多少个连续的0
}
memset(f, 0, sizeof f);
f[0][0] = 1;
for (int i = 1; i <= m; i ++)
for (int j = 0; j < 1 << n; j ++)
for (int k = 0; k < 1 << n; k ++)
if ((j & k) == 0 && (st[j | k]))
// j & k == 0 表示 i 列和 i - 1列同一行不同时捅出来
// st[j | k] == 1 表示 在 i 列状态 j, i - 1 列状态 k 的情况下是合法的.
f[i][j] += f[i - 1][k];
cout << f[m][0] << endl;
}
return 0;
}
边栏推荐
猜你喜欢
随机推荐
谈谈宝石方块游戏中的设计
企业即时通讯是什么?可以应用在哪些场景?
如何通过JMobile软件实现虹科物联网HMI/网关的报警功能?
Interview Question 04.12. Summation Path-dfs+Auxiliary Array Method
openssl查看证书信息
JVM内存和垃圾回收-11.执行引擎
位算符详解 按位与、或、异或、取反、左移、右移
【接入指南 之 直接接入】手把手教你快速上手接入HONOR Connect平台(下)
eager模式和graph模式 Tensorflow
背景视频铺满盒子
pyspark columns merge into one row
想玩转监控神器Prometheus吗?
剖析Framework面试—>>>冲击Android高级职位
NPDP|传统行业产品经理如何进行能力提升?
Toronto Research Chemicals霉菌毒素分析丨T2 四醇
人生苦短,开始用go
【FAQ】HarmonyOS ETS如何给组件设置边框
消息队列初见:一起聊聊引入系统mq 之后的问题
记录某博彩网站渗透
阿里云贾朝辉:云 XR 平台支持彼真科技呈现国风科幻虚拟演唱会