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

做没用的网站深圳集团网站开发

做没用的网站,深圳集团网站开发,网络营销的策划流程,旅游网站开发实训报告算法-DFS记忆化/动态规划-不同路径 II 1 题目概述 1.1 题目出处 https://leetcode.cn/problems/unique-paths-ii 1.2 题目描述 2 DFS记忆化 2.1 思路 注意题意#xff0c;每次要么往右#xff0c;要么往下走#xff0c;也就是说不能走回头路。但是仍有可能走到之前已经…算法-DFS记忆化/动态规划-不同路径 II 1 题目概述 1.1 题目出处 https://leetcode.cn/problems/unique-paths-ii 1.2 题目描述 2 DFS记忆化 2.1 思路 注意题意每次要么往右要么往下走也就是说不能走回头路。但是仍有可能走到之前已经访问过的节点。题意是要求走到终点的路径数假设往右可以走通往下也可以走通那么当前格子的走通方法数 往右走通方法数 往下走通方法数。 2.2 代码 class Solution {int m 0;int n 0;int[][] paths null;public int uniquePathsWithObstacles(int[][] obstacleGrid) {m obstacleGrid.length;n obstacleGrid[0].length;paths new int[m][n];return dfs(obstacleGrid, 0, 0);} private int dfs(int[][] obstacleGrid, int i, int j) {if (paths[i][j] 0) {return paths[i][j];}if (obstacleGrid[i][j] 1) {return 0;}if (i m - 1 j n - 1) {paths[i][j] 1;return 1;}int result 0;if (i m - 1) {result dfs(obstacleGrid, i 1, j);}if (j n - 1) {result dfs(obstacleGrid, i, j 1);}paths[i][j] result;return result;} }2.3 时间复杂度 O(m*n) 2.4 空间复杂度 O(m*n) 3 二维动态规划 3.1 思路 从上述DFS中思考可以推出动态规划表达式dp[i][j] dp[i1][j] dp[i][j1]。 这里注意两点 dp[m-1][n-1] 的值需要看obstacleGrid[m-1][n-1]是否为1如果为1代表是障碍则直接就返回0了。否则就填为1.从动态规划表达式可知需要i和j都从大到小遍历才可计算。 3.2 代码 class Solution {public int uniquePathsWithObstacles(int[][] obstacleGrid) {int m obstacleGrid.length;int n obstacleGrid[0].length;if (n 0) {return 1;}if (obstacleGrid[m - 1][n - 1] 1) {return 0;}// dp[i][j] dp[i1][j] dp[i][j1]int[][] dp new int[m][n];dp[m-1][n-1] 1;for (int i m - 1; i 0; i--) {for (int j n - 1; j 0; j--) {if (obstacleGrid[i][j] 1) {dp[i][j] 0;continue;}if (i m - 1) {dp[i][j] dp[i1][j];}if (j n - 1) {dp[i][j] dp[i][j1];}}}return dp[0][0];} }3.3 时间复杂度 O(M*N) 3.4 空间复杂度 O(M*N) 4 一维动态规划 4.1 思路 尝试压缩为一维动态规划。 考虑dp[i][j] dp[i1][j] dp[i][j1]那么如果我们每次固定i值从最后一行的j从大到小递减计算就能计算出最后一行的各个dp[j]值。然后i-1到上一行此时dp[j]依然表示此行每个位置的通终点方法数相当于是已经从当前位置累加了往下走的路线的方法数即dp[i][j] dp[i1][j] dp[i][j1]中的 dp[i1][j]那么我们只需要再计算本行的dp[i][j1]即可。综上所述我们可以压缩二维动态规划为一维动态规划dp[j] dp[j1] 4.2 代码 class Solution {public int uniquePathsWithObstacles(int[][] obstacleGrid) {int m obstacleGrid.length;int n obstacleGrid[0].length;if (n 0) {return 1;}if (obstacleGrid[m - 1][n - 1] 1) {return 0;}int[] dp new int[n];dp[n-1] 1;for (int i m - 1; i 0; i--) {for (int j n - 1; j 0; j--) {if (obstacleGrid[i][j] 1) {dp[j] 0;continue;}if (j n - 1) {dp[j] dp[j1];}}}return dp[0];} }4.3 时间复杂度 3.4 空间复杂度 O(N)
http://www.w-s-a.com/news/246106/

相关文章:

  • php网站建设文献综述怎么样提高网站排名
  • 专用车网站建设wordpress半透明
  • 石狮网站建设哪家好wordpress 3.9 漏洞
  • 为何建设单位网站找网络推广策畿
  • 用网站模板做网站动漫制作专业学校前十名
  • 网页 代码怎么做网站网站建设与维护课程设计
  • 网站制作哪家公司好企业名录联系电话
  • 做的网站怎么上传到网上wordpress图片之间空一行
  • 腾讯云建设网站视频vi报价单
  • 个人网站发布怎么做建设银行网站收款怎么打明细
  • 网站整体色调网站建设都有什么类型
  • 比较简洁大方的网站软件工程四大方向
  • 大家称赞的网站建设常德小学报名网站
  • 做网站怎么建文件夹百度网盘搜索神器
  • 企业有域名怎么做网站淘宝推广平台
  • 学网站开发去哪学药品销售推广方案
  • 哔哩哔哩h5播放器深圳网站seo外包公司哪家好
  • asp做的手机网站wordpress 文章title
  • 网站验证码目录wordpress内嵌播放器
  • 文明网网站建设南昌市建设规费标准网站
  • 安康有建网站的公司吗做网站用什么网名好
  • 济南网站制作哪家专业西安市城乡建设网官方网站
  • 网站建设有趣小游戏怎样让网站优化的方式
  • 昭通做网站儿童编程教学入门教程
  • eclipse静态网站开发软文广告投放平台
  • 网站建设教学视频济南做网站需要多少钱
  • 网站免费做软件市工商联官方网站建设方案
  • 网站建设大体包含英铭长沙网站建设
  • 网站建设培训学校北京如何搜索网站
  • discuz论坛模板哪些网站容易做seo优化