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

韩国风格网站整站源码站内免费推广

韩国风格网站整站源码,站内免费推广,网页设计公司理念,百度地图网站开发在解 LeetCode 的过程中#xff0c;路径计数问题是动态规划中一个经典的例子。今天我来分享一道非常基础但极具代表性的题目——不同路径。不仅适合初学者入门 DP#xff08;动态规划#xff09;#xff0c;还能帮助你打下递归思维的基础。 本文将介绍#xff1a; …在解 LeetCode 的过程中路径计数问题是动态规划中一个经典的例子。今天我来分享一道非常基础但极具代表性的题目——不同路径。不仅适合初学者入门 DP动态规划还能帮助你打下递归思维的基础。 本文将介绍 问题描述 解题思路包括递归记忆化搜索 代码实现与优化 时间复杂度 空间复杂度分析 进阶思考 问题描述 一个机器人位于一个 m x n 的网格左上角起点 Start。 机器人每次只能向 右 或 下 移动一步试图到达网格的右下角终点 Finish。 请问从起点到终点总共有多少条不同的路径 ✅ 示例 示例 1 输入: m 3, n 7 输出: 28示例 2 输入: m 3, n 2 输出: 3 解释: 1. 向右 - 向下 - 向下 2. 向下 - 向下 - 向右 3. 向下 - 向右 - 向下示例 3 输入: m 7, n 3 输出: 28示例 4 输入: m 3, n 3 输出: 6解题思路 1️⃣ 递归 记忆化搜索自顶向下 我们可以把每一步的选择抽象成一个状态转移问题 如果机器人在 (i, j) 位置它可以从 上面 (i-1, j) 或 左边 (i, j-1) 走过来。到达 (i, j) 的总路径数等于从 (i-1, j) 和 (i, j-1) 走过来的路径数之和。 状态转移方程 dp[i][j] dp[i-1][j] dp[i][j-1]边界条件 第一行和第一列上的每个位置的路径数都是 1因为只能往一个方向走。 为什么需要记忆化 如果不加记忆化递归会重复计算相同子问题时间复杂度会指数级上升。通过记忆化存储已经计算过的结果避免重复计算大大降低了复杂度。 代码实现Java class Solution {public int uniquePaths(int m, int n) {// 创建一个记忆数组存储子问题的解int[][] memo new int[m][n];return dfs(m - 1, n - 1, memo);}// 递归搜索函数i 表示行数j 表示列数private int dfs(int i, int j, int[][] memo) {// 边界情况越界直接返回 0if (i 0 || j 0) {return 0;}// 如果到达起点 (0,0)只有 1 条路径if (i 0 j 0) {return 1;}// 如果该位置已经计算过直接返回记忆值if (memo[i][j] ! 0) {return memo[i][j];}// 从上面和左边的路径数之和return memo[i][j] dfs(i - 1, j, memo) dfs(i, j - 1, memo);} }时间复杂度 空间复杂度分析 时间复杂度 O(m * n) 每个位置只会被访问一次避免了重复计算。 空间复杂度 O(m * n) 使用了一个二维数组来保存子问题的解。 进阶思考动态规划自底向上 除了递归记忆化还可以使用**动态规划DP**的方式自底向上求解避免了递归的栈消耗。 代码实现DP class Solution {public int uniquePaths(int m, int n) {int[][] dp new int[m][n];// 初始化边界条件for (int i 0; i m; i) dp[i][0] 1;for (int j 0; j n; j) dp[0][j] 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];} }时间复杂度: O(m * n) 空间复杂度: O(m * n)可以优化到 O(n)只用一维数组 其他进阶解法组合数学 如果你喜欢数学可以用组合数的公式来解这道题 一共需要移动 m-1 步向下n-1 步向右。总共 mn-2 步从中选择 m-1 步向下。 公式 C(mn−2,m−1)(mn−2)!(m−1)!⋅(n−1)!C(m n - 2, m - 1) \frac{(m n - 2)!}{(m - 1)! \cdot (n - 1)!} Java 实现 class Solution {public int uniquePaths(int m, int n) {long res 1;for (int i 1; i m - 1; i) {res res * (n - 1 i) / i;}return (int) res;} }时间复杂度: O(min(m, n)) 空间复杂度: O(1) 总结 使用 递归记忆化搜索 解决子问题避免重复计算。 使用 动态规划 解决自底向上的问题避免递归栈溢出。✨ 组合数学 提供最优解法时间复杂度低适合大规模输入。 如果你觉得这篇文章对你有帮助别忘了点赞、收藏⭐和关注欢迎在评论区和我交流更多动态规划的问题 更多 LeetCode 动态规划题解敬请期待
http://www.hkea.cn/news/14560884/

相关文章:

  • 做一套二级域名网站怎么做网站开发算是固定资产吗
  • 茂名专业做网站品牌建设包括哪些
  • 网站怎么收费的社交网站怎么制作
  • 上海网站建设开发公网站建设用什么系统
  • 有没有做美食的视频网站外部链接对网站的影响
  • 长沙网站策划简述网络营销的含义
  • 河南餐饮网站建设网络营销如何进行
  • 徐州优化网站建设济南网站建设联系方式
  • 哪个公司做网站好 知乎公明做企业网站
  • 企业门户网站布局特征网站域名过户查询
  • 东莞做网站设计制作做抽奖网站用什么cms
  • 上门做指甲哪个网站做外贸的经常浏览的三个网站
  • 泰坦科技网站建设19寸 网站做多大
  • 网站开发认证考试重庆做手机网站建设
  • 网站设计制作厂家有哪些joomla做的网站
  • 做网站和做阿里巴巴wordpress多级tree分类目录
  • 网站的建设目标有哪些小程序图片素材库
  • asp.net 4.0网站开...做公司网站麻烦吗
  • 动态ip建网站wordpress+360友链
  • 做网站须知WordPress 5.0升级
  • 虚拟机怎么做网站wordpress单页导航模版
  • 深圳市交易建设工程交易服务中心网站seo百度站长工具查询
  • 泰兴做网站电话网页设计与制作相关书籍
  • 聊城手机网站制作专业做网站建设制作服务
  • 国家示范校建设专题网站工商网站备案办法
  • 如何建设一个博客网站教育网站建设备案
  • php 家政网站ps切片工具做网站
  • 湖北省住房和建设厅官方网站企业网站怎么制作流程
  • 500元制作网站asp 网站数据库连接错误
  • 网站建设培训网站天辰建设网