当前位置: 首页 > news >正文

网站死链接石家庄网站建设时光

网站死链接,石家庄网站建设时光,制作网站首页,免费行业网站源码Leetcode: 62 不同路径 机器人从(0 , 0) 位置出发,到(m - 1, n - 1)终点。 基本思路 1、确定dp数组(dp table)以及下标的含义 dp[i][j] :表示从(0 ,0)出发,到(i, j) 有dp[i][j]条…

Leetcode: 62 不同路径

机器人从(0 , 0) 位置出发,到(m - 1, n - 1)终点。

基本思路

1、确定dp数组(dp table)以及下标的含义

dp[i][j] :表示从(0 ,0)出发,到(i, j) 有dp[i][j]条不同的路径。

2、确定递推公式

想要求dp[i][j],只能有两个方向来推导出来,即dp[i - 1][j] 和 dp[i][j - 1]。所以dp[i][j] = dp[i - 1][j] + dp[i][j - 1]。

3、dp数组的初始化

dp[i][0]一定都是1,因为从(0, 0)的位置到(i, 0)的路径只有一条,那么dp[0][j]也同理。

时间复杂度:O(m × n)

空间复杂度:O(m × n)

想不出来的时候,可以想想最后的步骤是由上一步怎么导出的。

class Solution {
public:int uniquePaths(int m, int n) {vector<vector<int>> dp(m, vector<int>(n,0));//初始化二维向量for(int i = 0; i < m; i++){dp[i][0] = 1;//初始化起始} for(int i = 0; i < n; i++){dp[0][i] = 1;}for(int i = 1; i < m; i++){for(int j = 1; j < n; j++){dp[i][j] = dp[i - 1][j]+ dp[i][j - 1];//递推公式}}return dp[m - 1][n - 1];}
};

当然也可以使用数论的方法。最后获得组合的方法如下。

C_{m+n-2}^{m-1}

但是这道题目要防止两个int相乘出现溢出的情况,所以要对两数相乘做特殊处理。需要在计算分子的时候,不断除以分母。

代码如下

代码随想录

时间复杂度:O(m)

空间复杂度:O(1)

class Solution {
public:int uniquePaths(int m, int n) {long long numerator = 1; // 分子int denominator = m - 1; // 分母int count = m - 1;int t = m + n - 2;while (count--) {numerator *= (t--);while (denominator != 0 && numerator % denominator == 0) {numerator /= denominator;denominator--;}}return numerator;}
};

Leetcode: 63 不同路径 II

这道题与上道题不一样的点,在于现在的的路径出现了障碍物。

1、dp数组的初始化

dp[i][0]一定都是1,但是如果遇到障碍物,那么后面的所有数组都是0,是无法达到的道路。

2、确定递推公式

想要求dp[i][j],只能有两个方向来推导出来,即dp[i - 1][j] 和 dp[i][j - 1]。所以dp[i][j] = dp[i - 1][j] + dp[i][j - 1]。如果出现障碍物,就跳过元素,这样这个元素还是0,那么即使相加相当于只有一个方向的信息。因此我们的递推公式还是dp[i][j] = dp[i - 1][j] + dp[i][j - 1]。遇到障碍物之后都是0。

时间复杂度:O(n × m)

空间复杂度:O(n × m)

class Solution {
public:int uniquePathsWithObstacles(vector<vector<int>>& obstacleGrid) {int m = obstacleGrid.size();int n = obstacleGrid[0].size();//注意维度的选择vector<vector<int>> dp(m, vector<int>(n,0));if (obstacleGrid[m - 1][n - 1] == 1 || obstacleGrid[0][0] == 1) //如果在起点或终点出现了障碍,直接返回0return 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] == 1) continue;dp[i][j] = dp[i - 1][j] + dp[i][j - 1];}}return dp[m - 1][n - 1];}
};
http://www.yayakq.cn/news/187878/

相关文章:

  • 高端企业网站定制公司网站建设工资
  • 亚马逊网站类型refile自己做的网站
  • 潮州哪里做网站上海人才引进政策
  • wordpress文章页怎么调用网站图片软件源地址大全
  • 怎么做一个盈利网站茶楼网站
  • 高清素材图片的网站重庆市建设工程信息网招标文件
  • 个旧网站建设护肤品网站建设前的行业分析
  • 山东网站备案网站开发网站网络公司有哪些
  • 成都网页设计价格优化设计方法
  • 哪有做奇石网站制作简历的免费网站
  • 济南定机票网站建设互联网推广营销隐迅推我选
  • 甘肃省建设厅特种工查询网站很长的网站域名怎么做短
  • 成都网站建设工作室做网站鞍山
  • 网站备案后 换服务器域名的网站建设方案书怎么写
  • 什么叫网站app商标查询官方网站
  • 服饰网站 模板自用电脑做网站
  • 怎么采集网站内容wordpress有微信插件
  • 比较好的h5网站唐山网站推广优化
  • 阜阳北京网站建设网页设计与制作教程期末考试试题
  • 自己做网站项目wordpress需要安装哪些插件
  • 广州做网站信科建设网站 推广方案
  • 五屏网站建设代理商asp.net mvc 网站开发之美
  • 网站申请书做的好的淘宝客网站
  • 业余从事网站开发12380 举报网站建设
  • 网站建设实践试卷苏州建设招投标网站
  • 龙华网站制作wordpress手机登录注册
  • 网站根目录相对路径搭建网站需要哪些步骤
  • 西安惠安小学网站建设步骤一
  • 律师推广网站排名外贸网站设计的公司
  • 网站开发技术有哪些如何推广自己的产品