hdu 1400 Mondriaan's Dream 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1400
题目意思:给出一个h * w的 大 矩形,需要用 1 * 2 的砖块去填充这个大矩形,问填充的方案数是多少。
这题参考这里的:
http://www.informatik.uni-ulm.de/acm/Locals/2000/solution/dream.c
把每一列的方格压缩为二进制编码,搜索上一列到当前列的状态转化是否能够成功。对于每一个位置,有3种放置方法:竖直、水平、不放
对每个方格,1表示填充砖块,0表示没有填充砖块。将一层的状态存放在一个二进制数中。
1、利用dfs,计算第一层的填充状态
2、从第 1 层向第 n 层,利用DP 递推结果。
变量from 和 to 的最大值,是宽为W的方格中都填充1,即(1<<W)-1,或者2^W-1
初始时,假设第 0 层都填充1,只有一种情况。
使用数组dp 表示每一层的递推关系,递推公式:
令:from[j] = state[j] [0], to[j] = state[j] [1],0 ≤ j < nstate
则dp[i+1] [to[j]] = ∑ dp[i] [from[j]], 0 ≤ j < nstate, 0 ≤ i < H
0 ≤ j < nstate
最近都是抄人代码的节奏= =,哎~~~~,继续努力吧!!!
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std; double dp[][]; // 存放各层的递推结果(当宽为11时,2^11-1 = 2047,开2100即可)
int state[][]; // 保存状态转化的结果
int H, W, nstate; // n: 当前从左往右数第n个方格,from:前n个方格在这一层编码, to:下一层的编码
// from 和 to的二进制长度与大长方形的宽度W是一致的
void dfs(int n, int from, int to)
{
if (n > W)
return;
// 整个宽度W填充完毕
if (n == W)
{
// 保存当前的状态转化
state[nstate][] = from;
state[nstate++][] = to;
return;
}
// 放置砖块的3种状态
// 水平放置砖块
dfs(n+, (from<<)+, (to<<)+); // 这个地方的+3, 后面的+1 不知道它想干嘛。希望有能之士可以指点指点
// 竖直放置砖块
dfs(n+, (from<<)+, to<<);
// 不放置
dfs(n+, from<<, (to<<)+);
} void DP()
{
memset(dp, , sizeof(dp));
// 第0层都填充1,只有一种情况
dp[][(<<W)-] = ;
for (int i = ; i < H; i++)
{
for (int j = ; j < nstate; j++)
dp[i+][state[j][]] += dp[i][state[j][]];
}
} int main()
{
while (scanf("%d%d", &H, &W) != EOF && (H+W))
{
if (H < W)
swap(H, W);
nstate = ;
dfs(, , );
DP();
printf("%.0f\n", dp[H][(<<W)-]);
}
}
hdu 1400 Mondriaan's Dream 解题报告的更多相关文章
- HDU - 1400 Mondriaan's Dream
HDU - 1400 思路: 轮廓线dp入门题 #include<bits/stdc++.h> using namespace std; #define fi first #define ...
- POJ 2411.Mondriaan's Dream 解题报告
题意: 给出n*m (1≤n.m≤11)的方格棋盘,用1*2的长方形骨牌不重叠地覆盖这个棋盘,求覆盖满的方案数. Solution: 位运算+状态压缩+dp ...
- [ACM] HDU 1400 Mondriaan's Dream (状态压缩,长2宽1长方形铺满)
Mondriaan's Dream Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
- hdu 1556.Color the ball 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1556 题目意思:有 n 个气球从左到右排成一排,编号依次为1,2,3,...,n.给出 n 对 a, ...
- hdu 1160 FatMouse's Speed 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1160 题目意思:给出一堆老鼠,假设有 n 只(输入n条信息后Ctrl+Z).每只老鼠有对应的weigh ...
- hdu 1879 继续畅通工程 解题报告
题目链接:http://code.hdu.edu.cn/showproblem.php?pid=1879 这条题目我的做法与解决Constructing Roads的解法是相同的. 0 表示没有连通: ...
- hdu 1233 还是畅通工程 解题报告
题目链接:http://code.hdu.edu.cn/showproblem.php?pid=1233 并查集的运用, 实质就是求最小生成树.先对所有的村庄距离从小到大排序,然后判断村庄之间是否属于 ...
- hdu 1213 How Many Tables 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1213 有关系(直接或间接均可)的人就坐在一张桌子,我们要统计的是最少需要的桌子数. 并查集的入门题,什 ...
- hdu 1272 小希的迷宫 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1272 第二条并查集,和畅通工程的解法类似.判断小希的迷宫不符合条件,即有回路.我的做法是,在合并两个集 ...
随机推荐
- 济南学习 Day5 T3 晚
回文串(palindromes) [题目描述] 判断是否能将字符串S分成三段非空回文串. [输入说明] 第一行一个整数T,表示数据组数. 对于每一个组,仅包含一个由小写字母组成的串. [输出说明] 对 ...
- ObjectDataSource配合存储过程(采用数据集)的使用(删除可以解决,但是编辑出错好像它的方法也无法解决
原文发布时间为:2008-08-01 -- 来源于本人的百度文章 [由搬家工具导入] ObjectDataSource是比较有意思的一个东西 通过在网络上遍访各位高手,终于自己有了一些心得体会。现总结 ...
- form表单提交file
form表单提交文件,这毫无疑问不是个好办法.但是,存在既有意义.既然H5都还让着东西存在着,呢么必然有其意义. form表单中的input type=file这个空间,不得不说奇丑无比!问题是还不能 ...
- set_include_path() &&get_include_path()用法
function initialize(){ set_include_path(get_include_path().PATH_SEPARATOR . "core/"); ...
- LinkedList类的基本方法的用法
package cn.zmh.LinkedList; import java.util.Iterator; import java.util.LinkedList; public class Link ...
- 前端微服务-面向web平台级应用的设计
从去年开始,前端领域就出现了一个‘微应用’的名词,说的是前端架构的一种设计思路,业内都把它和后端的微服务进行类比,当时忙于公司的项目.没有静下心来好好了解,现在项目结束,再加上最近看的几篇关于前端微服 ...
- Docker 基础底层架构浅谈
docker学习过程中,免不了需要学习下docker的底层技术,今天我们来记录下docker的底层架构吧! 从上图我们可以看到,docker依赖于linux内核的三个基本技术:namespaces.C ...
- ASP.NET Core默认注入方式下如何注入多个实现(多种方式) - sky 胡萝卜星星 - CSDN博客
原文:ASP.NET Core默认注入方式下如何注入多个实现(多种方式) - sky 胡萝卜星星 - CSDN博客 版权声明:本文为starfd原创文章,转载请标明出处. https://blog.c ...
- MySQL安装总是失败,提示缺少Visual Studio 2013 Redistributable
MySQL安装总是失败,提示缺少Visual Studio 2013 Redistributable,但是很疑惑,我明明已经安装了呀,原来问题出在版本上,以下提供了一个可以匹配新版本mysql的版本: ...
- react+flask+antd
待学习: 1.https://www.cnblogs.com/jlj9520/p/6625535.html 2.http://python.jobbole.com/87112/ 3.