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

电脑自带的做网站叫什么Wordpress启动mysql

电脑自带的做网站叫什么,Wordpress启动mysql,湖南人文科技学院王牌专业,菏泽郓城住房和城乡建设局网站题目难度: 中等 原题链接 今天继续更新 Leetcode 的剑指 Offer(专项突击版)系列, 大家在公众号 算法精选 里回复 剑指offer2 就能看到该系列当前连载的所有文章了, 记得关注哦~ 题目描述 一个机器人位于一个 m x n 网格的左上角 (起始点在下…

题目难度: 中等

原题链接

今天继续更新 Leetcode 的剑指 Offer(专项突击版)系列, 大家在公众号 算法精选 里回复 剑指offer2 就能看到该系列当前连载的所有文章了, 记得关注哦~

题目描述

一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。

机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish” )。

问总共有多少条不同的路径?

示例 1:

  • 输入:m = 3, n = 7
  • 输出:28

示例 2:

  • 输入:m = 3, n = 2
  • 输出:3
  • 解释:从左上角开始,总共有 3 条路径可以到达右下角。
    1. 向右 -> 向下 -> 向下
    2. 向下 -> 向下 -> 向右
    3. 向下 -> 向右 -> 向下

示例 3:

  • 输入:m = 7, n = 3
  • 输出:28

示例 4:

  • 输入:m = 3, n = 3
  • 输出:6

提示:

  • 1 <= m, n <= 100
  • 题目数据保证答案小于等于 2 * 10^9

题目思考

  1. 如何优化时间和空间复杂度?

解决方案

方法 1

  • 分析题目, 机器人只能向下或向右移动, 我们可以利用这一点, 累加当前坐标的左边和上边相邻坐标的路径数来得到当前坐标的路径数
  • 显然这就是动态规划的思路:
    • dp[r][c] 代表坐标(r,c)的路径数
    • 初始化 dp[0][0] = 1, 其他值全是 0, 表示开始时起点的路径数为 1
    • 然后进行状态转移: dp[r][c] = dp[r-1][c] + dp[r][c-1] (如果 r 或 c 为 0, 则相应的 r-1 或 c-1 的 dp 值就是 0, 只能从另一个方向转移而来)
    • 最终右下角坐标的 dp[m-1][n-1] 就代表总路径数
  • 下面的代码有详细的注释, 方便大家理解
复杂度
  • 时间复杂度 O(MN): 需要两重循环求 DP 值
  • 空间复杂度 O(MN): 二维 DP 数组的空间消耗
代码
class Solution:def uniquePaths(self, m: int, n: int) -> int:dp = [[0] * n for _ in range(m)]for r in range(m):for c in range(n):if (r, c) == (0, 0):# 起点dp值初始化为1dp[r][c] = 1else:# 左侧邻居路径数, 不存在时为0ldp = 0 if c == 0 else dp[r][c - 1]# 上侧邻居路径数, 不存在时为0udp = 0 if r == 0 else dp[r - 1][c]# 累加两个邻居的路径数dp[r][c] = ldp + udp# 最终结果就是右下角路径数return dp[m - 1][n - 1]

方法 2

  • 上面的 DP 做法固然可以解决这个问题, 那是否可以继续优化呢?
  • 答案是肯定的, 我们从另一个角度来思考这个问题, 机器人一共移动 m+n-2 次, 然后每次移动要么向下, 要么向右, 一共向下移动 m-1 次, 向右移动 n-1 次
  • 相当于从总移动次数 m+n-2 中选取 m-1 个, 我们可以利用数学求组合数的方法, 也即 C(m+n-2, m-1), 得到的值就是对应的总路径数
  • 这里可以额外进行一些优化, 使用 m 和 n 中的较小值来计算组合数, 对应的时间复杂度也是两者的较小值
  • 下面的代码有详细的注释, 方便大家理解
复杂度
  • 时间复杂度 O(min(M,N)): 求组合数时需要累乘 M-1 或 N-1 次, 取两者较小值
  • 空间复杂度 O(1): 没有使用额外变量
代码
class Solution:def uniquePaths(self, m: int, n: int) -> int:# 共有m+n-2次移动, 然后从中选择m-1次向下, 剩下n-1次向右# 所以总路径数就是组合数C(m+n-2,m-1) (也等于C(m+n-2,n-1))# 额外优化, 使用m和n的较小值来计算组合数mn = min(m, n)return math.comb(m + n - 2, mn - 1)

大家可以在下面这些地方找到我~😊

我的 GitHub

我的 Leetcode

我的 CSDN

我的知乎专栏

我的头条号

我的牛客网博客

我的公众号: 算法精选, 欢迎大家扫码关注~😊

算法精选 - 微信扫一扫关注我

http://www.yayakq.cn/news/461898/

相关文章:

  • 手机网站建设 新闻怎么在自己的网站上传视频
  • 织梦网站模板后台密码找回wordpress 评论可见
  • 阜阳手机网站制作海口网站建设发布
  • 公司主页网站怎么做石家庄网站建设找哪家
  • 建设网站需要公司吗兰州大学网页与网站设计
  • 网站制作前必须做的事情有哪些简洁白wordpress瀑布
  • 企业邮箱地址怎么填wordpress分类设置seo
  • 婚恋网站 没法做简单的wordpress模板
  • 做平面设计的网站微信分销商城
  • 大连专业模板网站制作公司wordpress运行php文件下载
  • 网站开发导航oneup wordpress
  • 汕头食品骏域网站建设网站建设基础书籍
  • 网站制作公司怎么运营青岛正规的网站建设公司
  • 现在建网站可以赚钱吗视频素材网免费
  • 有哪些比较好的做ppt好的网站咨询公司组织架构
  • 请问做网站需要什么木疙瘩h5官网
  • 西安建筑公司网站建设国外游戏网站设计
  • 辽icp备鞍山公司中企动力提供网站建设宠物网站制作内容
  • 用织梦系统做的2个网站要把它都上传到服务器上吗推广服务商
  • 广东省城乡建设厅网站首页网站域名备案注销
  • 北京建站报价求个网站你明白的 知乎
  • 全球采购网站遵义网站开发公司
  • 网站建设策划书的基本格式邮箱注册申请官网
  • 怎么用dw网站怎么建设电子电路自学网站
  • 上海高端网站开发公司网站建设 分析
  • 某一网站seo策划方案网站首页三张海报做多大
  • 技术支持凯里网站建设开发微信小程序游戏要多少钱
  • 中文域名网站链接无法打开免费网站推广网址
  • 视频网站自己怎么做企业网站的制作哪家好
  • 上海建设三类人员网站wordpress 柒比贰主题