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

LeetCode 3665. 统计镜子反射路径数目

在这里插入图片描述
很经典的题型,但由于有方向限制,在更新 dp 时需要多考虑方向。

定义:dp[i][j][0]dp[i][j][0]dp[i][j][0] 表示从上方到达 (i,j)(i, j)(i,j)的路径数,dp[i][j][1]dp[i][j][1]dp[i][j][1] 表示从左方到达 (i,j)(i, j)(i,j)的路径数。
则到达某个格子的总路径数就是 dp[i][j][0]+dp[i][j][1]dp[i][j][0] + dp[i][j][1]dp[i][j][0]+dp[i][j][1]

更新时,分方向讨论。
若上方为空格,则:dp[i][j][0]=dp[i−1][j][0]+dp[i−1][j][1]dp[i][j][0]=dp[i-1][j][0]+dp[i-1][j][1]dp[i][j][0]=dp[i1][j][0]+dp[i1][j][1]
若左方为空格,则:dp[i][j][1]=dp[i][j−1][0]+dp[i][j−1][1]dp[i][j][1]=dp[i][j-1][0]+dp[i][j-1][1]dp[i][j][1]=dp[i][j1][0]+dp[i][j1][1]

若上方为镜子,则:dp[i][j][0]=dp[i−1][j][1]dp[i][j][0]=dp[i-1][j][1]dp[i][j][0]=dp[i1][j][1]
若左方为镜子,则:dp[i][j][1]=dp[i][j−1][0]dp[i][j][1]=dp[i][j-1][0]dp[i][j][1]=dp[i][j1][0]

代码如下:

#define MOD 1000000007
class Solution {
public:int uniquePaths(vector<vector<int>>& grid) {int m = grid.size(), n = grid[0].size();int ans = 0;vector dp(m, vector<vector<long long int> >(n, vector<long long int>(2, 0)));dp[0][0][0] = 1;for(int i = 0;i<m;i++){for(int j = 0;j<n;j++){if(i==0 && j==0) continue;if(i > 0){if(grid[i-1][j]==0){dp[i][j][0] = (dp[i-1][j][0] + dp[i-1][j][1])%MOD;} else{dp[i][j][0] = dp[i-1][j][1]%MOD;}}if(j>0){if(grid[i][j-1]==0){dp[i][j][1] = (dp[i][j-1][1] + dp[i][j-1][0])%MOD;} else{dp[i][j][1] = dp[i][j-1][0]%MOD;}}}}if(grid[m-1][n-1] == 1){return 0;} else{return (dp[m-1][n-1][0] + dp[m-1][n-1][1]) %MOD;}}
};
http://www.dtcms.com/a/360515.html

相关文章:

  • react-virtualized React 应用中高效渲染大型列表和表格数据的库
  • Synchronized 概述
  • 【LeetCode】18、四数之和
  • LeeCode 37. 解数独
  • 并发编程——10 CyclicBarrier的源码分析
  • Selenium 等待机制:编写稳定可靠的自动化脚本
  • spi总线
  • 7.2elementplus的表单布局与模式
  • MCP SDK 学习二
  • 艾体宝案例 | 数据驱动破局:DOMO 如何重塑宠物零售门店的生存法则
  • Python 2025:AI代理、Rust与异步编程的新时代
  • 张柏芝亮相林家谦演唱会 再次演绎《任何天气》
  • Spring MVC 九大组件源码深度剖析(五):HandlerAdapter - 处理器的执行引擎
  • 三、环境搭建之Docker安装mysql
  • 一、计算机系统知识
  • Springcloud-----Nacos
  • 【influxdb】InfluxDB 2.x 线性写入详解
  • 层次分析法
  • Redis实现短信登录
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘SQLModel’问题
  • 37. 解数独
  • 解锁Tensor Core性能:深入探索CUDA Warp矩阵操作
  • Dify构建AI应用
  • FART 主动调用组件深度解析:破解 ART 下函数抽取壳的终极武器
  • #Datawhale 组队学习#8月-工作流自动化n8n入门-3
  • 第七章 使用角色和Asible内容集合简化Playbook
  • 4.4 光照(4) - 高光反射
  • 硬件工程师成长之路:从入门到精通的技术旅程
  • [Plecs基础知识系列]建立自定义模块/子系统(Subsystem)
  • C++ 面试高频考点 力扣 69. x 的平方根 二分查找 题解 每日一题