骨牌覆盖问题

骨牌覆盖问题:

用1*2骨牌完美覆盖n*m棋盘,求方案数

一、2*m

如果骨牌横着放,只能两个横着的骨牌摞在一起

如果竖着放,恰好占一列

所以dp[i]=dp[i-1]+dp[i-2]

即斐波那契数列

二、3*m

可以想到一个递推式:f[n]=a2*f[n-2]+a4*f[n-4]+a6*f[n-6]+……+an*f[0]

ai(i是偶数)是未知的系数

即覆盖3*i棋盘且无法按某一列将3*i棋盘分成左右两部分的方案数

当i=2时,有3种方案

当i>=4(i为偶数)时,只有2种

因为考虑最左上角的骨牌,如果竖着放,要想无法被分割,除了最右上角的竖着放,其余都要横着放

如果最左上角的骨牌横着放,与他竖着放是对称的

所以f[n]=3*f[n-2]+2*f[n-4]+2*f[n-6]+……+2*f[0]

同理得f[n-2]=3*f[n-4]+2*f[n-6]+……+2*f[0]

两式相减,得f[n]=4*f[n-2]-f[n-4]

三、n*m

https://www.cnblogs.com/TheRoadToTheGold/p/12202781.html

原文地址:https://www.cnblogs.com/TheRoadToTheGold/p/12203111.html

时间: 2024-10-10 06:28:52

骨牌覆盖问题的相关文章

编程之美 --1 : 骨牌覆盖问题·一

题目1 : 骨牌覆盖问题·一 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 骨牌,一种古老的玩具.今天我们要研究的是骨牌的覆盖问题:我们有一个2xN的长条形棋盘,然后用1x2的骨牌去覆盖整个棋盘.对于这个棋盘,一共有多少种不同的覆盖方法呢?举个例子,对于长度为1到3的棋盘,我们有下面几种覆盖方式: 提示:骨牌覆盖 提示:如何快速计算结果 输入 第1行:1个整数N.表示棋盘长度.1≤N≤100,000,000 输出 第1行:1个整数,表示覆盖方案数 MOD 1999

随便玩玩系列之一:SPOJ-RNG+51nod 算法马拉松17F+51nod 1034 骨牌覆盖v3

先说说前面的SPOJ-RNG吧,题意就是给n个数,x1,x2,...,xn 每次可以生成[-x1,x1]范围的浮点数,把n次这种操作生成的数之和加起来,为s,求s在[A,B]内的概率 连续形的概率,想象为一个n维长方体,有两个平面与这个几何图形相割,于是就变成了求面(体)积问题,一般要去重,n维区域系数:s^n/n!,至于区间问题,直接前缀之差搞定 然后就是悲催的算法马拉松17F题了...其实是道好题来的,只是出题人不知世界上还有这题,然后某大牛把思路理清后把答案直接搬了过来 经典的1*2骨牌覆

hihoCoder #1162 : 骨牌覆盖问题·三

#1162 : 骨牌覆盖问题·三 Time Limit:10000ms Case Time Limit:1000ms Memory Limit:256MB 描述 前两周里,我们讲解了2xN,3xN骨牌覆盖的问题,并且引入了两种不同的递推方法.这一次我们再加强一次题目,对于给定的K和N,我们需要去求KxN棋盘的覆盖方案数. 提示:KxN骨牌覆盖 输入 第1行:2个整数N.表示棋盘宽度为k,长度为N.2≤K≤7,1≤N≤100,000,000 输出 第1行:1个整数,表示覆盖方案数 MOD 1235

[hihoCoder] 题目1 : 骨牌覆盖问题·二

时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 上一周我们研究了2xN的骨牌问题,这一周我们不妨加大一下难度,研究一下3xN的骨牌问题?所以我们的题目是:对于3xN的棋盘,使用1x2的骨牌去覆盖一共有多少种不同的覆盖方法呢?首先我们可以肯定,奇数长度一定是没有办法覆盖的:对于偶数长度,比如2,4,我们有下面几种覆盖方式: 提示:3xN骨牌覆盖 输入 第1行:1个整数N.表示棋盘长度.1≤N≤100,000,000 输出 第1行:1个整数,表示覆盖方案数 MOD 12

hihoCoder 骨牌覆盖问题·一 hiho一下 第四十一周

时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 骨牌,一种古老的玩具.今天我们要研究的是骨牌的覆盖问题:我们有一个2xN的长条形棋盘,然后用1x2的骨牌去覆盖整个棋盘.对于这个棋盘,一共有多少种不同的覆盖方法呢?举个例子,对于长度为1到3的棋盘,我们有下面几种覆盖方式: 提示:骨牌覆盖 提示:如何快速计算结果 输入 第1行:1个整数N.表示棋盘长度.1≤N≤100,000,000 输出 第1行:1个整数,表示覆盖方案数 MOD 19999997 样例输入 62247

骨牌覆盖

P2070 - 骨牌覆盖 Description 有一个3*n的棋盘让你放入若干1*2的骨牌,要求将整棋盘恰好覆盖满.求方案数! Input 一个整数n. Output 方案数模12357的值. Sample Input 2 Sample Output 3 Hint 1<=n<=100000000 td p { margin-bottom: 0cm } pre.cjk { font-family: "Droid Sans Fallback", monospace } p {

hihoCode #1151 : 骨牌覆盖问题&#183;二

#1151 : 骨牌覆盖问题·二 Time Limit:10000ms Case Time Limit:1000ms Memory Limit:256MB 描述 上一周我们研究了2xN的骨牌问题,这一周我们不妨加大一下难度,研究一下3xN的骨牌问题?所以我们的题目是:对于3xN的棋盘,使用1x2的骨牌去覆盖一共有多少种不同的覆盖方法呢?首先我们可以肯定,奇数长度一定是没有办法覆盖的:对于偶数长度,比如2,4,我们有下面几种覆盖方式: 提示:3xN骨牌覆盖 输入 第1行:1个整数N.表示棋盘长度.

3xN骨牌覆盖——hihoCoder

3xN骨牌覆盖 在2xN的骨牌覆盖问题中,我们有递推式子 (0,1)xM^n=(f[n-1],f[n]). 我们考虑能否在3xN的情况下找到同样的式子. 但在实际的推导过程可以发现,对于3xN的覆盖,对应的f数值公式比2xN复杂太多.我们需要换个角度来思考推导公式. 在我们放置骨牌的过程中,一定是放好一行之后再放置下一行.根据摆放的方式,可能会产生很多种不同的形状,而这些形状之间是否具有某些递推关系呢? 如果他们存在一定的递推关系,则我们可以根据第i行的方案数来推导第i+1行的方案数.这样一行一

hiho42 : 骨牌覆盖问题&#183;二

描述 上一周我们研究了2xN的骨牌问题,这一周我们不妨加大一下难度,研究一下3xN的骨牌问题?所以我们的题目是:对于3xN的棋盘,使用1x2的骨牌去覆盖一共有多少种不同的覆盖方法呢?首先我们可以肯定,奇数长度一定是没有办法覆盖的:对于偶数长度,比如2,4,我们有下面几种覆盖方式: 提示:3xN骨牌覆盖 输入 第1行:1个整数N.表示棋盘长度.1≤N≤100,000,000 输出 第1行:1个整数,表示覆盖方案数 MOD 12357 样例输入 62247088 样例输出 4037 提示:3xN骨牌

1007 正整数分组 1010 只包含因子2 3 5的数 1014 X^2 Mod P 1024 矩阵中不重复的元素 1031 骨牌覆盖

1007 正整数分组 将一堆正整数分为2组,要求2组的和相差最小. 例如:1 2 3 4 5,将1 2 4分为1组,3 5分为1组,两组和相差1,是所有方案中相差最少的. Input 第1行:一个数N,N为正整数的数量. 第2 - N+1行,N个正整数. (N <= 100, 所有正整数的和 <= 10000) Output 输出这个最小差 Input示例 5 1 2 3 4 5 Output示例 1这题不就是小李打怪兽吗,不知道谁模仿谁,呵呵,刚还是我编的题里的,dp,证明一下(要证明什么自