码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 状态压缩dp蒙德里安的梦想


    求把 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. 1 2
    2. 1 3
    3. 1 4
    4. 2 2
    5. 2 3
    6. 2 4
    7. 2 11
    8. 4 11
    9. 0 0

    输出样例:

    1. 1
    2. 0
    3. 1
    4. 2
    5. 3
    6. 5
    7. 144
    8. 51205

     

    1. #include
    2. using namespace std;
    3. const int N = 12, M = 1 << N;
    4. int st[M];
    5. long long f[N][M];
    6. int main(){
    7. int n, m;
    8. while (cin >> n >> m && (n || m)){
    9. for (int i = 0; i < 1 << n; i ++){
    10. int cnt = 0;
    11. st[i] = true;
    12. for (int j = 0; j < n; j ++)
    13. if (i >> j & 1){
    14. if (cnt & 1) st[i] = false; // cnt 为当前已经存在多少个连续的0
    15. cnt = 0;
    16. }
    17. else cnt ++;
    18. if (cnt & 1) st[i] = false; // 扫完后要判断一下最后一段有多少个连续的0
    19. }
    20. memset(f, 0, sizeof f);
    21. f[0][0] = 1;
    22. for (int i = 1; i <= m; i ++)
    23. for (int j = 0; j < 1 << n; j ++)
    24. for (int k = 0; k < 1 << n; k ++)
    25. if ((j & k) == 0 && (st[j | k]))
    26. // j & k == 0 表示 i 列和 i - 1列同一行不同时捅出来
    27. // st[j | k] == 1 表示 在 i 列状态 j, i - 1 列状态 k 的情况下是合法的.
    28. f[i][j] += f[i - 1][k];
    29. cout << f[m][0] << endl;
    30. }
    31. return 0;
    32. }

     

  • 相关阅读:
    SpringBoot里全局 非expcetion异常处理 非WebFlex
    java19-集合
    Java配置28-CentOS7下配置redis主从关系
    【C++代码】最大二叉树,合并二叉树,二叉搜索树中的搜索,验证二叉搜索树--代码随想录
    【如何用爬虫玩转石墨文档?】
    FISCO BCOS 3.0【01】搭建第一个区块链网络
    经验终结:arduino 环境下,esp8266 定时器的使用说明
    【计算机网络】图解应用层协议
    以梦为马,不负韶华|电巢科技&延安大学飞鹰计划实习班精彩回顾
    接口测试入门
  • 原文地址:https://blog.csdn.net/m0_61949623/article/details/126230974
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号