Leetcode 3665. Twisted Mirror Path Count

  • [Leetcode 3665. Twisted Mirror Path Count](#Leetcode 3665. Twisted Mirror Path Count)
    • [1. 解题思路](#1. 解题思路)
    • [2. 代码实现](#2. 代码实现)

1. 解题思路

这一题相较于上一题就直接很多了,就是一个动态规划,直接写就行了。

2. 代码实现

给出python代码实现如下:

python 复制代码
MOD = 10**9+7

class Solution:
    def uniquePaths(self, grid: List[List[int]]) -> int:
        n, m = len(grid), len(grid[0])
        
        DIRECTION = {0: (1, 0), 1: (0, 1)}

        @lru_cache(None)
        def dp(i, j, direction):
            if i == n-1 and j == m-1:
                return 1
            if i < 0 or i >= n or j < 0 or j >= m:
                return 0
            if grid[i][j] == 0:
                return (dp(i+1, j, 0) + dp(i, j+1, 1)) % MOD
            while 0 <= i < n and 0 <= j < m and grid[i][j] == 1:
                direction = 1-direction
                dx, dy = DIRECTION[direction]
                i, j = i+dx, j+dy
            return dp(i, j, direction) % MOD

        return dp(0, 0, 0)

提交代码评测得到:耗时耗时2733ms,占用内存306.37MB。

相关推荐
2601_9618451510 小时前
新高考一卷真题2025|真题PDF全科整理
线性代数·矩阵·pdf·动态规划·概率论·高考
随意起个昵称11 小时前
线性dp-LIS题目5(导弹拦截,二分优化)
c++·算法·动态规划
8Qi813 小时前
LeetCode 5:最长回文子串(Longest Palindromic Substring)—— 题解
算法·leetcode·职场和发展·动态规划
8Qi81 天前
LeetCode 1143 & 718:最长公共子序列 / 最长重复子数组
算法·leetcode·职场和发展·动态规划
随意起个昵称1 天前
线性dp-综合刷题1(Not Alone)
算法·动态规划
-森屿安年-1 天前
1137. 第 N 个泰波那契数
c++·动态规划
8Qi81 天前
LeetCode 115 & 392:不同子序列 / 判断子序列
算法·leetcode·职场和发展·动态规划
8Qi81 天前
LeetCode 72:编辑距离(Edit Distance)—— 题解
算法·leetcode·职场和发展·动态规划
8Qi81 天前
LeetCode 583. 两个字符串的删除操作
算法·leetcode·职场和发展·动态规划
汉克老师1 天前
GESP6级C++考试语法知识(五十五、动态规划----背包问题(八、混合背包)
c++·动态规划·dp·背包问题·gesp六级·混合背包问题