• ​力扣解法汇总790. 多米诺和托米诺平铺


    目录链接:

    力扣编程题-解法汇总_分享+记录-CSDN博客

    GitHub同步刷题项目:

    https://github.com/September26/java-algorithms

    原题链接:力扣


    描述:

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

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

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

    示例 1:

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

    示例 2:

    输入: n = 1
    输出: 1
    

    提示:

    • 1 <= n <= 1000

    解题思路:

    * 解题思路:
    * 这一定是一道动态规划的题,如果我们去掉L型,那么就是一个斐波那契额数列,F(n)=F(n-1)+F(n-2)
    * 加上L形状,我们仍然可以按照这个思路来。
    * 开头只有四种可能,-,=,L,「。
    * -和=开头的,我们可以归结为斐波那契额数列,f(n)=f(n-1)+f(n-2)
    * L和「开头的,我们可以归结为一类问题,使用F(n)来表示,所以可以转换为f(n)=f(n-1)+f(n-2)+F(n)
    * 我们再来看下F(n)怎解决?
    * L开头的话,只有两种可能:
    * L开头,以┐结尾,中间包含若干-形,其数量为f(n-3)+f(n-5)+f(n-7)...
    * L开头,以」结尾,中间包含若干-形状,其数量为f(n-4)+f(n-6)+f(n-8)...
    * 两种类型累加,就是F(n)的数量。
    * 最后,每次计算对值求模,得到我们想要的结果

    代码:

    1. public class Solution790 {
    2. Map<Integer, Integer> fMap = new HashMap<>();
    3. int flag = 10_0000_0000 + 7;
    4. public int numTilings(int n) {
    5. fMap.put(0, 1);
    6. fMap.put(1, 1);
    7. fMap.put(2, 2);
    8. int index = 3;
    9. while (index <= n) {
    10. int indexValue = fMap.get(index - 1) % flag + fMap.get(index - 2) % flag;
    11. indexValue = indexValue % flag;
    12. indexValue += (2 * F(index)) % flag;
    13. indexValue = indexValue % flag;
    14. fMap.put(index, indexValue);
    15. index++;
    16. }
    17. return fMap.get(n);
    18. }
    19. private int F(int index) {
    20. //L开头,」结尾
    21. int sum = 0;
    22. for (int i = 0; i <= index - 3; i += 2) {
    23. sum += fMap.get(index - 3 - i) % flag;
    24. sum = sum % flag;
    25. }
    26. if (index <= 3) {
    27. return sum;
    28. }
    29. for (int i = 0; i <= index - 4; i += 2) {
    30. sum += (fMap.get(index - 4 - i) % flag);
    31. sum = sum % flag;
    32. }
    33. //L开头,┐结尾
    34. return sum;
    35. }
    36. }

  • 相关阅读:
    go-zero 微服务实战系列(二、服务拆分)
    tensorRT模型推理时动态shape
    激活函数作用以及 sigmoid和softmax
    LocalDate、LocalTime、LocalDateTime常用方法
    Linux常用命令
    spring boot 引入hive
    【Java】File类、递归
    期刊分类一览
    spring 常见面试题
    算法训练营day42|动态规划 part04:0-1背包 (01背包问题基础(两种解决方案)、LeetCode 416.分割等和子集)
  • 原文地址:https://blog.csdn.net/AA5279AA/article/details/127919968