博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode 62. Unique Paths LeetCode 63 Unique Paths II 不同的路径之二
阅读量:3503 次
发布时间:2019-05-20

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

初识动态规划。

格点(i,j)。由于只能从上格点(i-1,j)或左格点(i,j-1)到达,并且两者路径是不重复的

因此path[i][j] = path[i-1][j]+path[i][j-1]。

最近要开始看动态规划了。

class Solution {public:    int uniquePaths(int m, int n) {        vector
> ans(m,vector
(n,1)); for(int i=1;i

63II 自己写的方法1特复杂。

class Solution {public:    int uniquePathsWithObstacles(vector
>& obstacleGrid) { //obstacleGrid={
{0,0,0},{0,1,0},{0,0,0}}; int m=obstacleGrid.size(); int n=obstacleGrid[0].size(); int i,j,j1,i1; vector
> ans(m,vector
(n,1)); if(m>=1&&n>=1) { for(j=0;j

方法2:

class Solution {public:    int uniquePathsWithObstacles(vector
>& obstacleGrid) { if (obstacleGrid.empty() || obstacleGrid[0].empty() || obstacleGrid[0][0] == 1) return 0; vector
> dp(obstacleGrid.size(), vector
(obstacleGrid[0].size(), 0)); for (int i = 0; i < obstacleGrid.size(); ++i) { for (int j = 0; j < obstacleGrid[i].size(); ++j) { if (obstacleGrid[i][j] == 1) dp[i][j] = 0; else if (i == 0 && j == 0) dp[i][j] = 1; else if (i == 0 && j > 0) dp[i][j] = dp[i][j - 1]; else if (i > 0 && j == 0) dp[i][j] = dp[i - 1][j]; else dp[i][j] = dp[i - 1][j] + dp[i][j - 1]; } } return dp.back().back(); }};

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

你可能感兴趣的文章
redis 持久化详解,RDB和AOF是什么?他们优缺点是什么?运行流程是什么?
查看>>
spring注解版(一)
查看>>
SpringBoot中访问控制层(controller)得不到Json数据
查看>>
react项目报出警告Warning: Cannot update during an existing state transition (such as within `render`).
查看>>
BFC(Block Formatting Context)
查看>>
什么是作用域,什么是闭包,什么是作用域链
查看>>
惰性求值,面向对象
查看>>
lodash源码分析之baseSlice()函数
查看>>
数据结构之列表
查看>>
发布/订阅模式 vs 观察者模式
查看>>
es5中的arguments对象
查看>>
git本地仓库和远程仓库关联,分支重命名
查看>>
js对象的深拷贝,你真的觉得很简单吗?
查看>>
你真的了解map方法吗?手动实现数组map方法。
查看>>
带你手动实现call方法,让你收获满满
查看>>
前端知识体系
查看>>
查找入职员工时间排名倒数第三的员工所有信息
查看>>
使用join查询方式找出没有分类的电影id以及名称
查看>>
Qt教程(2) : Qt元对象系统
查看>>
驱动开发误用指针错误:Unable to handle kernel NULL pointer dereference at virtual address
查看>>