leetcode 动态规划(基础版)不同路径II

题目:

题解:

一种可行的方案是,因为障碍物无法到达也无法从障碍物过来,所以遇上障碍物时将对应的dp位置设为0即可,这样非常巧妙简单地解决了这个问题。

cpp 复制代码
int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {
        int dp[105][105]={0};
        dp[0][1]=1;
        for(int i=1;i<=obstacleGrid.size();i++){
            for(int j=1;j<=obstacleGrid[0].size();j++){
                if(obstacleGrid[i-1][j-1]==1)continue;
                dp[i][j]=dp[i-1][j]+dp[i][j-1];
            }
        }
        return dp[obstacleGrid.size()][obstacleGrid[0].size()];
    }
相关推荐
POLITE38 分钟前
Leetcode 42.接雨水 JavaScript (Day 3)
javascript·算法·leetcode
Tim_108 分钟前
【算法专题训练】36、前缀树路径和
算法
好易学·数据结构13 分钟前
可视化图解算法76:最大子数组和
数据结构·算法·leetcode·面试·动态规划·力扣·笔试
副露のmagic30 分钟前
更弱智的算法学习 day13
学习·算法
青岛少儿编程-王老师1 小时前
CCF编程能力等级认证GESP—C++1级—20251227
java·c++·算法
Sylus_sui1 小时前
git中如何从某次历史提交节点上创建一个新的分支
git·算法·哈希算法
nn在炼金1 小时前
大模型领域负载均衡技术
人工智能·算法·负载均衡
falldeep2 小时前
Pandas入门指南
数据结构·算法·leetcode·pandas
natide2 小时前
表示/嵌入差异-4-闵可夫斯基距离(Minkowski Distance-曼哈顿距离-欧氏距离-切比雪夫距离
人工智能·深度学习·算法·机器学习·自然语言处理·概率论
ulias2122 小时前
多态理论与实践
java·开发语言·前端·c++·算法