当前位置: 首页 > news >正文

LeetCode、790. 多米诺和托米诺平铺【中等,二维DP,可转一维】

文章目录

  • 前言
  • LeetCode、790. 多米诺和托米诺平铺【中等,二维DP,可转一维】
    • 题目与分类
    • 思路
      • 二维解法
      • 二维转一维
  • 资料获取

前言

博主介绍:✌目前全网粉丝2W+,csdn博客专家、Java领域优质创作者,博客之星、阿里云平台优质作者、专注于Java后端技术领域。

涵盖技术内容:Java后端、算法、分布式微服务、中间件、前端、运维、ROS等。

博主所有博客文件目录索引:博客目录索引(持续更新)

视频平台:b站-Coder长路


LeetCode、790. 多米诺和托米诺平铺【中等,二维DP,可转一维】

题目与分类

题目链接:LeetCode、790. 多米诺和托米诺平铺

分类:动态规划/线性DP


思路

思路描述:以第i列来作为递推形式,初始第一列(二行一列)是固定满的,目的就是初始化,之后每一列(可以说每一组)都是基于上一列的四个状态来与当前可组合的多米诺和托米诺来构成新的一种组合。

下面是多米诺和托米诺的各种状态:

image-20240205211326549

下面图示i位置的多个图案右边的序号下每一个正方形其中的第一列就指的是上一层四个状态中的其中一个状态,根据当前应该成为的状态来看是否可以添加一个多米诺和托米诺来组成当前所属的状态,经过n轮这样子推导,最终即可推导得到所有满平铺的方案数量。

image-20240205210 331776


二维解法

复杂度分析:时间复杂度O(n);空间复杂度O(n)

class Solution {public static final int MOD = 1000000007;//按照【列】来进行递推方程 提前设置好每一列的状态情况//n最大1000//dp[0][0-2] = 0  dp[0][3] = 1//递推:n列  i为列//   dp[i][0] = dp[i - 1][3]//   dp[i][1] = dp[i - 1][0] + dp[i - 1][2]//   dp[i][2] = dp[i - 1][0] + dp[i - 1][1]//   dp[i][3] = dp[i - 1][0] + dp[i - 1][1] + dp[i - 1][2] + dp[i - 1][3]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] % MOD;dp[i][1] = MODD(dp[i - 1][0], dp[i - 1][2]);dp[i][2] = MODD(dp[i - 1][0], dp[i - 1][1]);dp[i][3] = MODD(MODD(dp[i - 1][0], dp[i - 1][1]), MODD(dp[i - 1][2], dp[i - 1][3]));}return dp[n][3];}// 对两个int进行取%public int MODD(int a, int b) {return (a + b) % MOD;}
}

image-20240205205810571


二维转一维

说明:可以看到当前题解是基于二维DP来推导的,在二维中我们可以看到当前层每次计算新的数量值时之后使用到上一层,那么就i很容易的二维转一维。

复杂度分析:时间复杂度O(n);空间复杂度O(1)

class Solution {public static final int MOD = 1000000007;//二维转一维public int numTilings(int n) {int t1 = 0, t2 = 0, t3 = 0, t4 = 1;//递推for (int i = 1; i <= n; i ++) {int tmp1 = t1, tmp2 = t2, tmp3 = t3, tmp4 = t4;t1 = tmp4 % MOD;t2 = MODD(tmp1, tmp3);t3 = MODD(tmp1, tmp2);t4 = MODD(MODD(tmp1, tmp2), MODD(tmp3, tmp4));}return t4;}// 对两个int进行取%public int MODD(int a, int b) {return (a + b) % MOD;}
}

image-20240205205711554


资料获取

大家点赞、收藏、关注、评论啦~

精彩专栏推荐订阅:在下方专栏👇🏻

  • 长路-文章目录汇总(算法、后端Java、前端、运维技术导航):博主所有博客导航索引汇总
  • 开源项目Studio-Vue—校园工作室管理系统(含前后台,SpringBoot+Vue):博主个人独立项目,包含详细部署上线视频,已开源
  • 学习与生活-专栏:可以了解博主的学习历程
  • 算法专栏:算法收录

更多博客与资料可查看👇🏻获取联系方式👇🏻,🍅文末获取开发资源及更多资源博客获取🍅


整理者:长路 时间:2024.2.5

http://www.lryc.cn/news/294916.html

相关文章:

  • Python 的 sys 模块常用方法
  • Kafka 使用手册
  • STM32F407移植OpenHarmony笔记7
  • cortexM c语言和汇编嵌套编程
  • 国外传输大文件必选工具
  • Redis渗透SSRF的利用
  • 【深度学习】基于PyTorch架构神经网络学习总结(基础概念基本网络搭建)
  • 专业排版设计软件:QuarkXPress 2024 for mac中文激活版
  • 3593 蓝桥杯 查找最大元素 简单
  • Postgresql数据库存储过程中的事务处理
  • Redis——缓存的持久化
  • kafka-splunk数据通路实践
  • C语言第十九弹---指针(三)
  • TCP/IP LWIP FPGA 笔记
  • 2024年海外优青项目申报指南
  • threejs之常用贴图
  • Unity类银河恶魔城学习记录3-1 EnemyStateMachine源代码 P47
  • 使用webstorm调试vue 2 项目
  • 深度学习缝模块怎么描述创新点?(附写作模板+涨点论文)
  • html,css,js速成
  • 《Docker极简教程》--Docker基础--基础知识(一)
  • Web html和css
  • Three.js学习6:透视相机和正交相机
  • ❤ React18 环境搭建项目与运行(地址已经放Gitee开源)
  • 2024 RTE行业(实时互动行业)人才发展学习总结
  • 92.网游逆向分析与插件开发-游戏窗口化助手-显示游戏数据到小助手UI
  • Stable Diffusion 模型下载:majicMIX fantasy 麦橘幻想
  • docker compose安装minio
  • 二、SSM 整合配置实战
  • 『运维备忘录』之 Yum 命令详解