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

苏州网站推广服务沈阳商城网站开发

苏州网站推广服务,沈阳商城网站开发,网站开发手册下载,个人电脑建立网站力扣746.使用最小花费爬楼梯【easy】 力扣62.不同路径【medium】 力扣63.不同路径Ⅱ【medium】 力扣343.整数拆分【medium】 力扣96.不同的二叉搜索树【medium】 一、力扣746.使用最小花费爬楼梯【easy】 题目链接:力扣746.使用最小花费爬楼梯 视频链接&#xff1a…

力扣746.使用最小花费爬楼梯【easy】
力扣62.不同路径【medium】
力扣63.不同路径Ⅱ【medium】
力扣343.整数拆分【medium】
力扣96.不同的二叉搜索树【medium】

一、力扣746.使用最小花费爬楼梯【easy】

题目链接:力扣746.使用最小花费爬楼梯
在这里插入图片描述
视频链接:代码随想录
题解链接:灵茶山艾府

1、思路

  • 和前面几道题思路一致,要将问题转化成子问题

  • 在这里插入图片描述

  • 在这里插入图片描述

  • 时间复杂度: O ( n ) O(n) O(n)

  • 空间复杂度:前两个 O ( n ) O(n) O(n) ,第三个优化到 O ( 1 ) O(1) O(1)

2、代码

class Solution:def minCostClimbingStairs(self, cost: List[int]) -> int:n = len(cost)# def dfs(i):#     if i <= 1 :#         return 0#     res = min(dfs(i - 1) + cost[i -1], dfs(i - 2) + cost[i - 2])#     return res# return dfs(n)# @cache# def dfs(i):#     if i <= 1:#         return 0#     res = min(dfs(i - 1) + cost[i - 1], dfs(i - 2) + cost[i - 2])#     return res# return dfs(n)# dp = [0] * (n + 1)# dp[0] = dp[1] = 0 # for k in range(2, n + 1):#     dp[k] = min(dp[k - 1] + cost[k - 1], dp[k - 2] + cost[k - 2])# return dp[n]f0 = f1 = 0for i in range(1,n):new_f = min(f0 + cost[i - 1], f1 + cost[i])f0 = f1f1 = new_freturn f1

二、力扣62.不同路径【medium】

题目链接:力扣62.不同路径
在这里插入图片描述
视频链接:代码随想录
题解链接:灵茶山艾府

1、思路

  • 转为子问题

    • 在这里插入图片描述
  • 明确 d p [ i ] [ j ] dp[i][j] dp[i][j] 的含义:表示从 ( 0 , 0 ) (0,0) (0,0) ( i , j ) (i,j) (i,j) 的路径数

  • 状态方程: d p [ i ] [ j ] = d p [ i − 1 ] [ j ] + d p [ i ] [ j − 1 ] dp[i][j] = dp[i-1][j] + dp[i][j-1] dp[i][j]=dp[i1][j]+dp[i][j1]

  • 边界 / 初始值:

    • 用递归时: d f s ( − 1 , j ) = d f s ( i , − 1 ) = 0 , d f s ( 0 , 0 ) = 1 dfs(-1,j) = dfs(i,-1) = 0, dfs(0,0) = 1 dfs(1,j)=dfs(i,1)=0,dfs(0,0)=1
    • 转成dp是:有两种处理方式,生成的矩阵的大小不一致
      • d p [ 0 ] [ 1 ] = 1 dp[0][1] = 1 dp[0][1]=1
      • d p [ i ] [ 0 ] = d p [ 0 ] [ j ] = 1 dp[i][0] = dp[0][j] = 1 dp[i][0]=dp[0][j]=1
  • 时间复杂度: O ( m ∗ n ) O(m * n) O(mn) 状态个数 * 单个状态的计算时间

2、代码

class Solution:def uniquePaths(self, m: int, n: int) -> int:# @cache# def dfs(i, j):#     if i < 0 or j < 0:#         return 0#     if i == 0 and j == 0:#         return 1#     return dfs(i, j - 1 ) + dfs(i - 1, j)# return dfs(m - 1, n - 1)# dp = [[0] * (n + 1) for _ in range(m + 1)]# dp[0][1] = 1# for i in range(m):#     for j in range(n):#         dp[i + 1][j + 1] = dp[i][j + 1] + dp[i + 1][j]# return dp[m][n]dp = [[0] * n for _ in range(m) ]for i in range(m):dp[i][0] = 1for j in range(n):dp[0][j] = 1for i in range(1,m):for j in range(1,n):dp[i][j] = dp[i - 1][j] + dp[i][j - 1]return dp[m - 1][n - 1]

三、力扣63.不同路径Ⅱ【medium】

题目链接:力扣63.不同路径Ⅱ
left =x300
视频链接:代码随想录
题解链接:灵茶山艾府

1、思路

  • 多了障碍物,其他与62一致
  • 碰到障碍物,不可以走,意思就是无效路径,之前的也白搭
  • 所以碰到障碍, d p [ i ] [ j ] = 0 dp[i][j] = 0 dp[i][j]=0
  • 时间复杂度: O ( m ∗ n ) O(m * n) O(mn) 状态个数 * 单个状态的计算时间

2、代码

class Solution:def uniquePathsWithObstacles(self, obstacleGrid: List[List[int]]) -> int:m, n = len(obstacleGrid), len(obstacleGrid[0])dp = [[0] * (n + 1) for _ in range(m + 1)]dp[0][1] = 1for i, row in enumerate(obstacleGrid):for j, x in enumerate(row):if x == 0:dp[i + 1][j + 1] = dp[i][j + 1] + dp[i + 1][j]return dp[m][n]
class Solution:def uniquePathsWithObstacles(self, obstacleGrid: List[List[int]]) -> int:m, n = len(obstacleGrid), len(obstacleGrid[0])@cachedef dfs(i,j):if i < 0 or j < 0 or obstacleGrid[i][j]:return 0if i == 0 and j == 0 :return 1return dfs(i - 1, j) + dfs(i, j - 1)return dfs(m - 1, n - 1)
class Solution:def uniquePathsWithObstacles(self, obstacleGrid: List[List[int]]) -> int:m, n = len(obstacleGrid), len(obstacleGrid[0])dp = [[0] * n for _ in range(m)]for i in range(m):if obstacleGrid[i][0] == 0:  # 遇到障碍物时,直接退出循环,后面默认都是0dp[i][0] = 1else:breakfor j in range(n):if obstacleGrid[0][j] == 0:dp[0][j] = 1else:breakfor i in range(1, m):for j in range(1, n):if obstacleGrid[i][j] == 1:continuedp[i][j] = dp[i - 1][j] + dp[i][j - 1]return dp[m - 1][n - 1]

3、代码问题

  • 在这里插入图片描述

四、力扣343.整数拆分【medium】

题目链接:力扣343.整数拆分
![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/e7e38c115c89402c837125c1d877f43a.png#pic_ left =x300)

视频链接:代码随想录
题解链接:Krahets

1、思路

  • 利用均值不等式说明 当取等时,乘机最大
  • 在这里插入图片描述
  • 在这里插入图片描述
  • 时间复杂度: O ( 1 ) O(1) O(1)
  • 在这里插入图片描述

2、代码

class Solution:def integerBreak(self, n: int) -> int:if n <= 3:return n - 1a, b = n // 3, n % 3if b == 0:return int(math.pow(3,a))if b == 1:return int(math.pow(3, a - 1) * 4)if b == 2:return int(math.pow(3, a) * 2)

五、力扣96.不同的二叉搜索树【medium】

题目链接:力扣96.不同的二叉搜索树
在这里插入图片描述

视频链接:代码随想录
题解链接:画手大鹏

1、思路

  • d p [ n ] dp[n] dp[n]:n个结点存在二叉排序树的个数

  • f ( i ) f(i) f(i):以i为根的二叉搜索树的个数

  • 在这里插入图片描述

  • 在这里插入图片描述

  • 时间复杂度: O ( n 2 ) O(n^2) O(n2)

2、代码

class Solution:def numTrees(self, n: int) -> int:dp = [0] * (n + 1)dp[0] = 1for i in range(1,n + 1):for j in range(1, i + 1):dp[i] += dp[j-1] * dp[i - j]return dp[n]


文章转载自:

http://GFWA5e5X.gwxwL.cn
http://HYRHH7o6.gwxwL.cn
http://UsgVytQM.gwxwL.cn
http://3bc4pcTd.gwxwL.cn
http://58j1bTPo.gwxwL.cn
http://VAxVZtrT.gwxwL.cn
http://AekllTSt.gwxwL.cn
http://Idqq59cM.gwxwL.cn
http://SBGK7sWB.gwxwL.cn
http://3eSYTDLB.gwxwL.cn
http://yb1FXLda.gwxwL.cn
http://EpR4gYOP.gwxwL.cn
http://tzASqG8r.gwxwL.cn
http://6mQm0azZ.gwxwL.cn
http://5YH8nJB8.gwxwL.cn
http://1umvuGuS.gwxwL.cn
http://zJtqMPuw.gwxwL.cn
http://atbSRRWy.gwxwL.cn
http://4xz81eTm.gwxwL.cn
http://TcpHOWyh.gwxwL.cn
http://L4WtVSv6.gwxwL.cn
http://DKtmQ9xh.gwxwL.cn
http://IfPQHBcA.gwxwL.cn
http://R3TG7FYL.gwxwL.cn
http://e8SloWBB.gwxwL.cn
http://0RphnOVD.gwxwL.cn
http://OO4GEzO4.gwxwL.cn
http://VHNzJ7zP.gwxwL.cn
http://0ETDeWiB.gwxwL.cn
http://Ka8KKCrR.gwxwL.cn
http://www.dtcms.com/wzjs/777317.html

相关文章:

  • error 403 网站拒绝显示django网站开发视频教程
  • 人社门户网站建设方案网站开发设计流程时间表
  • 贵州网站制作公司建立网站的元素有哪些
  • 网站排名点击工具做宠物网站导航应该写什么字
  • 电子商务网站建设运行环境舟山 做企业网站
  • 盘锦建设小学网站net域名大网站
  • 上海哪家做公司网站如何提高网站内容质量
  • 一元夺宝网站建设2017珠宝行网站建设方案
  • 企业网站建设有什么义县网站建设
  • 网站建设不完整 审核线上企业订单管理系统网站
  • wordpress 换域名 全站301重定向做seo_教你如何选择网站关键词
  • 计算机网络技术网站开发wordpress网站关键字
  • 百姓网网站建设网站开发用php还是js
  • 如何建学校网站wordpress动态插件
  • 广州建设厅电工网站江门建站网站模板
  • 树苗网站源码什邡建设局网站
  • 美文的手机网站淘宝客网站一定要备案
  • 域名注册网站 简称十堰公司做网站
  • 博客做公司网站北京建站公司兴田德润信任
  • 网站开发学哪一个好公关公司多少钱一个月
  • 有视频接口怎么做网站课题组网站建设
  • 济宁网站建设只要500元wordpress瀑布墙
  • 东莞网站建设咨询外贸做企业什么网站
  • 小说网站建设需要什么js跳转到别的网站
  • 婚纱定制网站哪个好韶关网站开发
  • 昆明网站制作企业海淘手表网站
  • 深圳wap网站建设7天精通网站建设实录简介242
  • 中国建设银行个人网站银行广州专业网页制作
  • 建设银行 北京招聘网站开购物网站需要多少钱
  • 客户网站建设需要什么资料网站开发app开发培训