博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode----63. Unique Paths II
阅读量:4113 次
发布时间:2019-05-25

本文共 835 字,大约阅读时间需要 2 分钟。

链接:

大意:

给定一个二维整数矩阵,矩阵中的元素为0/1。1表示该位置是障碍位置。求出从起点(左上角)到达终点(右下角)有多少种方案?注意:无法越过障碍位置。例子:

思路:

和上一题思路一样:

采用动态规划的解法。无法越过障碍位置==从起点到障碍位置的方案数为0.

代码:

class Solution {    public int uniquePathsWithObstacles(int[][] o) {        if (o.length == 0 || o[0][0] == 1)            return 0;        int[][] dp = new int[o.length + 1][o[0].length + 1];        dp[1][1] = 1;        for (int i = 1; i < dp.length; i++) {            for (int j = 1; j < dp[i].length; j++) {                if (i != 1 || j != 1) {                    if (o[i - 1][j - 1] == 1)                        dp[i][j] = 0;                    else                         dp[i][j] = dp[i - 1][j] + dp[i][j - 1];                    }            }        }        //System.out.println(Arrays.deepToString(dp));        return dp[dp.length - 1][dp[0].length - 1];    }}

结果:

结论:

动态规划:最优子结构+子问题重叠 

 

 

转载地址:http://rvesi.baihongyu.com/

你可能感兴趣的文章
飞机换乘次数最少问题的两种解决方案
查看>>
有向无回路图的理解
查看>>
设计模式中英文汇总分类
查看>>
MFC实现五子棋游戏
查看>>
WPF实现蜘蛛纸牌游戏
查看>>
单例模式
查看>>
工厂方法模式
查看>>
模板方法模式
查看>>
数据结构之队列、栈
查看>>
数据结构之树
查看>>
数据结构之二叉树
查看>>
二叉树非递归遍历算法思悟
查看>>
红黑树算法思悟
查看>>
从山寨Spring中学习Spring IOC原理-自动装配注解
查看>>
实例区别BeanFactory和FactoryBean
查看>>
Spring后置处理器BeanPostProcessor的应用
查看>>
Spring框架的ImportSelector到底可以干嘛
查看>>
Mysql中下划线问题
查看>>
微信小程序中使用npm过程中提示:npm WARN saveError ENOENT: no such file or directory
查看>>
Xcode 11 报错,提示libstdc++.6 缺失,解决方案
查看>>