LeetCode63:不同路径Ⅱ

题目描述

一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 "Start" )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 "Finish")。

现在考虑网格中有障碍物。那么从左上角到右下角将会有多少条不同的路径?

网格中的障碍物和空位置分别用 1 和 0 来表示。


代码

cpp 复制代码
class Solution {
public:
    /*
        dp[i][j]:从[0,0]到[i,j]的路线数
        递推公式:if(obs[i][j] == 0)   相当于将障碍物所在的位置 dp[i][j]的值为0
                      dp[i][j] = dp[i-1][j] + dp[i][j-1]
        初始化:   dp[0][i] = 1,如果遇到dp[0][i]为障碍物,则break,因为后面都到达不了
                   dp[i][0]类似
    
    */
    int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {
        int m = obstacleGrid.size();
        int n = obstacleGrid[0].size();
        vector<vector<int>> dp(m, vector<int>(n, 0));

        //初始化第一列
        for (int i = 0; i < m && obstacleGrid[i][0] == 0; i++) {
            dp[i][0] = 1;
        }
        //初始化第一行
        for (int i = 0; i < n && obstacleGrid[0][i] == 0; i++) {
            dp[0][i] = 1;
        }

        for (int i = 1; i < m; i++) {
            for (int j = 1; j < n; j++) {
                if (obstacleGrid[i][j] == 0)
                    dp[i][j] = dp[i - 1][j] + dp[i][j - 1];
            }
        }
        return dp[m - 1][n - 1];
    }
};
相关推荐
造夢先森5 分钟前
常见数据结构及算法
数据结构·算法·leetcode·贪心算法·动态规划
iAkuya14 分钟前
(leetcode)力扣100 29删除链表的倒数第 N 个结点(双指针)
算法·leetcode·链表
汉克老师36 分钟前
GESP2025年12月认证C++二级真题与解析(编程题2 (黄金格))
c++·二维数组·gesp二级·gesp2级·分支判断
ShineSpark37 分钟前
C++单例模式的演进:从经典实现到现代线程安全范式
c++·安全·单例模式
良木生香42 分钟前
【数据结构-初阶】二叉树---链式存储
c语言·数据结构·c++·算法·蓝桥杯·深度优先
胡萝卜3.01 小时前
程序构建核心解析:从预处理到链接的完整指南
运维·服务器·c++·人工智能·操作系统·编译原理·系统编成
Binky6781 小时前
力扣--贪心(2)+动规(1)
算法·leetcode·职场和发展
长安er10 小时前
LeetCode215/347/295 堆相关理论与题目
java·数据结构·算法·leetcode·
元亓亓亓10 小时前
LeetCode热题100--62. 不同路径--中等
算法·leetcode·职场和发展
小白菜又菜10 小时前
Leetcode 1925. Count Square Sum Triples
算法·leetcode