美文网首页
790. 多米诺和托米诺平铺(难度:中等)

790. 多米诺和托米诺平铺(难度:中等)

作者: 一直流浪 | 来源:发表于2022-12-20 19:27 被阅读0次

题目链接:https://leetcode.cn/problems/domino-and-tromino-tiling/

题目描述:

有两种形状的瓷砖:一种是 2 x 1 的多米诺形,另一种是形如 "L" 的托米诺形。两种形状都可以旋转。

img

给定整数 n ,返回可以平铺 2 x n 的面板的方法的数量。返回对 109 + 7 取模 的值。

平铺指的是每个正方形都必须有瓷砖覆盖。两个平铺不同,当且仅当面板上有四个方向上的相邻单元中的两个,使得恰好有一个平铺有一个瓷砖占据两个正方形。

示例 1:

img
输入: n = 3
输出: 5
解释: 五种不同的方法如上所示。

示例 2:

输入: n = 1
输出: 1

提示:

  • 1 <= n <= 1000

解法:动态规划

考虑一种情况,在第i列之前的所有列都已经被瓷砖覆盖,在第i列以及之后都没有被覆盖。第i列从1开始,那么第i列有下面四种覆盖的方式:

  • 一个方块都没有被覆盖,记为状态0;
  • 上面方块被覆盖,记为状态1;
  • 下面方块被覆盖,记为状态2;
  • 两个方块都被覆盖,记为状态3。

使用 dp[i][j] 表示平铺到第i列时,各状态对应的方法数量。考虑第 i - 1 和第 i 列正方形,他们之间的状态转移图如下:(灰色表示已经铺好的,红色代码新铺的)

fig1

第0列,dp[0][0] = 0dp[0][1] = 0dp[0][2] = 0dp[0][3] = 1,对应的状态转移方程(i>0)如下:

  • dp[i][0] = dp[i-1][3]
  • dp[i][1] = dp[i-1][3] + dp[i-1][2]
  • dp[i][2] = dp[i-1][3] + dp[i-1][1]
  • dp[i][3] = dp[i-1][0] + dp[i-1][1] + dp[i-1][2] + + dp[i-1][3]

代码:

class Solution {
    static final int MOD = 1000000007;

    public int numTilings(int n) {
        int[][] dp = new int[n + 1][4];
        dp[0][3] = 1;
        for (int i = 1; i <= n; i++) {
            dp[i][0] = dp[i - 1][3];
            dp[i][1] = (dp[i - 1][0] + dp[i - 1][2]) % MOD;
            dp[i][2] = (dp[i - 1][0] + dp[i - 1][1]) % MOD;
            dp[i][3] = (((dp[i - 1][0] + dp[i - 1][1]) % MOD + dp[i - 1][2]) % MOD + dp[i - 1][3]) % MOD;
        }
        return dp[n][3];
    }
}

相关文章

  • 790. 多米诺与诺米诺平铺(Python)

    难度:★★★☆☆类型:数组方法:动态规划 力扣链接请移步本题传送门[https://leetcode-cn.com...

  • 多米诺效应

    和闺女一起玩多米诺,感觉多米诺第一个锻炼人的耐力和细心。没有耐力和细心度是完成不了多米诺的排列的。有时候排上半...

  • 算法 2.5 贪心算法:行相等的最少多米诺旋转【leetcode

    题目描述 在一排多米诺骨牌中,A[i] 和 B[i] 分别代表第 i 个多米诺骨牌的上半部分和下半部分一个多米诺是...

  • 多米诺骨牌效应

    你会玩多米诺骨牌吗?这是一种有趣的游戏。 多米诺骨牌的玩法是一个意大利女孩多米诺发明的 。到19世纪,多米诺已经成...

  • 多米诺起床仪式

    大家都听过,多米诺骨牌,但是不一定知道多米诺起床仪式吧。这是个什么东东呢? 多米诺起床仪式是《漫步...

  • 多米诺骨形状-柱状多米诺骨元素设计-ppt模板分享

    多米诺骨形状-柱状多米诺骨元素设计-ppt模板分享 所有元素可编辑。提供pptx格式和key格式免费下载。 下载链...

  • 多米诺新玩法

    今天晚上结合多米诺游戏,和大家培训了一下看板的设计和使用。 因为之前玩过多米诺游戏,所以觉得是个不错的工具和载体,...

  • 意象对话读书笔记:二

    今天看了两个案例《死亡多米诺》和《沉默的对白》。 先说《死亡多米诺》,由于来访者的自杀,从而怀疑自己,产生自杀念头...

  • 最重要的事,只有一件

    多米诺骨牌效应 2009年11月13日,魏捷斯多米诺公司在荷兰进行了一场破纪录的表演---4491863块多米诺骨...

  • 琳德曼湖和滴翠湖健行

    琳德曼湖Lindeman Lake和滴翠湖Greendrop Lake健行:12公里来回爬高400米本来算中等难度...

网友评论

      本文标题:790. 多米诺和托米诺平铺(难度:中等)

      本文链接:https://www.haomeiwen.com/subject/ftdpqdtx.html