LeetCode 面试打卡 4: 动态规划 - DataWhale 导学

这篇具有很好参考价值的文章主要介绍了LeetCode 面试打卡 4: 动态规划 - DataWhale 导学。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

动态规划代码实现需要注意的问题
  1. 数组dp的初始化大小不正确,需要根据题目中所给的数据确定好dp数组的大小。一般为[m,n]即可

  2. 数组dp的初始化逻辑有误:根据题目条件,初始化dp数组

  3. 状态转移方程不正确:根据题目中的变量设定状态转移方程。

121. 买卖股票的最佳时机

给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。

你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。

返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0

示例 1:

输入:[7,1,5,3,6,4]
输出:5
解释:在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。
注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格;同时,你不能在买入前卖出股票。

一次遍历完成,最大盈利的计算, 同时记录 minPrice最小价格和maxProfit最大利润的两个变量。

class Solution:
    def maxProfit(self, prices: List[int]) -> int:
        # 设定初始变量 
        minPrice = inf
        maxProfit = 0
        # 进行遍历
        for price in prices:
            maxProfit = max(maxProfit,price-minPrice)
            minPrice = min(minPrice,price)

        return maxProfit

买卖股票2,

方法1:

因为可以交易多次,所以抓住所有上涨的趋势进行买入卖出就可以了。

方法2(动态规划):

动态规划 dp[i][0] 没有股票持有的最大利润 dp[i][1] 持有股票拥有的最大利润

没有持有股票的转移方程

d p [ i ] [ 0 ] = m a x ( d p [ i − 1 ] [ 0 ] , d p [ i − 1 ] [ 1 ] + p r i c e [ i ] ) dp[i][0] = max( dp[i-1][0],dp[i-1][1]+price[i]) dp[i][0]=max(dp[i1][0],dp[i1][1]+price[i])

持有股票的动态规划方程

d p [ i ] [ 1 ] = m a x ( d p [ i − 1 ] [ 1 ] , d p [ i − 1 ] [ 0 ] − p r i c e [ i ] ) dp[i][1]=max(dp[i-1][1],dp[i-1][0]-price[i]) dp[i][1]=max(dp[i1][1],dp[i1][0]price[i])

class Solution:
    def maxProfit(self, prices):
        n = len(prices)
        dp = [[0 for _ in range(2)] for _ in range(n)]
        dp[0][0] = 0
        dp[0][1] = -prices[0]
        for i in range(1, n):
            dp[i][0] = max(dp[i - 1][0], dp[i - 1][1] + prices[i])
            dp[i][1] = max(dp[i - 1][1], dp[i - 1][0] - prices[i])
        return dp[n - 1][0]

1143. 最长公共子序列

给定两个字符串 text1text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 ,返回 0

一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情况下删除某些字符(也可以不删除任何字符)后组成的新字符串。

  • 例如,"ace""abcde" 的子序列,但 "aec" 不是 "abcde" 的子序列。

两个字符串的 公共子序列 是这两个字符串所共同拥有的子序列。

示例 1:

输入:text1 = “abcde”, text2 = “ace”
输出:3
解释:最长公共子序列是 “ace” ,它的长度为 3

使用动态规划求解,设定dp数组 dp[n][m],n,m分别为两个字符串的长度。

dp[n][m]也就表示s1[:i]s2[:j]这两个子字符串的最大公共子序列长度。

设置i,j分别为s1,s2子字符串各自的长度.

状态转移方程

s 1 [ i ] = s 2 [ j ] : d p [ i ] [ j ] = d p [ i − 1 ] [ j − 1 ] + 1 s_1[i]=s_2[j]:dp[i][j]=dp[i-1][j-1]+1 s1[i]=s2[j]:dp[i][j]=dp[i1][j1]+1

s 1 [ i ] ! = s 2 [ j ] : d p [ i ] [ j ] = m a x ( d p [ i − 1 ] [ j ] , d p [ i ] [ j − 1 ] ) s_1[i]!=s_2[j]:dp[i][j] =max(dp[i-1][j],dp[i][j-1]) s1[i]!=s2[j]:dp[i][j]=max(dp[i1][j],dp[i][j1])

初始状态

i=0时dp[i][j]=0

j=0时dp[i][j]=0

代码:

class Solution:
    def longestCommonSubsequence(self, text1: str, text2: str) -> int:
        # 定义dp数组 初始状态
        n,m = len(text1),len(text2)
        dp= [[0]*(m+1)  for _ in range(n+1)]

        # 完善动态规划数组
        for i in range(1,n+1):
            for j in range(1,m+1):
                if text1[i-1] == text2[j-1]:
                    dp[i][j] = dp[i-1][j-1] + 1
                else:
                    dp[i][j] = max(dp[i][j-1],dp[i-1][j])
        return dp[n][m]

64. 最小路径和

给定一个包含非负整数的 mxn 网格 grid ,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。

说明每次只能向下或者向右移动一步。文章来源地址https://www.toymoban.com/news/detail-856946.html

class Solution:
    def minPathSum(self, grid: List[List[int]]) -> int:
        m, n = len(grid), len(grid[0])
        dp = [[0]*n for _ in range(m)]  # 修正了dp数组的大小

        dp[0][0] = grid[0][0]
        for i in range(1, m):  # 初始化第一列
            dp[i][0] = dp[i-1][0] + grid[i][0]
        for j in range(1, n):  # 初始化第一行
            dp[0][j] = dp[0][j-1] + grid[0][j]

        for i in range(1, m):
            for j in range(1, n):
                dp[i][j] = min(dp[i-1][j], dp[i][j-1]) + grid[i][j]  # 使用min寻找最小路径和

        return dp[m-1][n-1]

到了这里,关于LeetCode 面试打卡 4: 动态规划 - DataWhale 导学的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【手撕算法|动态规划系列No.2】leetcode面试题 08.01. 三步问题

    个人主页:平行线也会相交 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 平行线也会相交 原创 收录于专栏【手撕算法系列专栏】【LeetCode】 🍔本专栏旨在提高自己算法能力的同时,记录一下自己的学习过程,希望对大家有所帮助 🍓希望我们一起努力、成长,共同进步。

    2024年02月12日
    浏览(51)
  • LeetCode练习七:动态规划上:线性动态规划

    参考《OI Wiki动态规划》、《算法通关手册》动态规划篇 1.1 动态规划简介    动态规划(Dynamic Programming) :简称 DP ,是一种通过把原问题分解为相对简单的子问题的方式而求解复杂问题的方法。 动态规划方法与分治算法类似,却又不同于分治算法。 「动态规划的核心思想

    2024年02月12日
    浏览(58)
  • [LeetCode]-动态规划-4

    记录 LeetCode 刷题时遇到的动态规划相关题目,第四篇 枚举算法:首先对整个矩阵生成一个 row 数组,其中 row[i][j] 表示从 mat[i][j] 开始往左连续的 1 的个数 然后枚举的思路是,枚举所有的 mat[i][j],求以 mat[i][j] 为右下角的子矩形 的个数,然后求和,具体的求法是枚举以 mat[

    2024年01月24日
    浏览(28)
  • leetcode 动态规划(单词拆分)

    139.单词拆分 力扣题目链接(opens new window) 给定一个非空字符串 s 和一个包含非空单词的列表 wordDict,判定 s 是否可以被空格拆分为一个或多个在字典中出现的单词。 说明: 拆分时可以重复使用字典中的单词。 你可以假设字典中没有重复的单词。 示例 1: 输入: s = “leetcode”

    2024年02月22日
    浏览(31)
  • leetcode-动态规划【背包问题】

    基础背包: 416. 分割等和子集 1049. 最后一块石头的重量ii 494. 目标和 474. 一和零 完全背包: 518. 零钱兑换ii 377. 组合总和iv 70. 爬楼梯 322. 零钱兑换 279. 完全平方数 139. 单词拆分 多重背包: n件物品和最大承受重量为w的背包,其中第i件物品的重量是weight[i],得到的价值是val

    2023年04月08日
    浏览(24)
  • 【LeetCode】--- 动态规划 集训(一)

    题目地址: 1137. 第 N 个泰波那契数 泰波那契序列 Tn 定义如下: T0 = 0, T1 = 1, T2 = 1 , 且在 n = 0 的条件下 Tn+3 = Tn + Tn+1 + Tn+2 给你整数 n ,请返回第 n 个泰波那契数 Tn 的值。 示例 1: 输入:n = 4 输出:4 解释: T_3 = 0 + 1 + 1 = 2 T_4 = 1 + 1 + 2 = 4 示例 2: 输入:n = 25 输出:1389537 因为

    2024年03月25日
    浏览(40)
  • LeetCode —— 动态规划

    持续更新中..................................... 509. 斐波那契数 斐波那契数 (通常用  F(n)  表示)形成的序列称为 斐波那契数列 。该数列由  0  和  1  开始,后面的每一项数字都是前面两项数字的和。也就是:F(0) = 0,F(1) = 1 F(n) = F(n - 1) + F(n - 2),其中 n 1。 示例: 输入: n

    2024年02月09日
    浏览(24)
  • LeetCode——动态规划篇(一)

    刷题顺序及思路来源于代码随想录,网站地址:https://programmercarl.com  目录 509. 斐波那契数 - 力扣(LeetCode) 70. 爬楼梯 - 力扣(LeetCode) 746. 使用最小花费爬楼梯 - 力扣(LeetCode) 62. 不同路径 - 力扣(LeetCode)  63. 不同路径 II - 力扣(LeetCode) 斐波那契数  (通常用  F(n)  表

    2024年02月09日
    浏览(26)
  • LeetCode——动态规划篇(二)

     刷题顺序及思路来源于代码随想录,网站地址:https://programmercarl.com  目录 343. 整数拆分 - 力扣(LeetCode) 96. 不同的二叉搜索树 - 力扣(LeetCode) 416. 分割等和子集 - 力扣(LeetCode) 1049. 最后一块石头的重量 II - 力扣(LeetCode)   给定一个正整数  n  ,将其拆分为  k  个 

    2024年02月07日
    浏览(27)
  • LeetCode——动态规划

    一、一维数组:斐波那契数列 爬楼梯70简单 dp定义: dp[i]表示爬到第i阶有多少种不同的方式 状态转移方程: dp[i] = dp[i-1] + dp[i-1] (每次可以爬1或2个台阶) 边界条件: dp[0] = 1; dp[1] = 1;(满足dp[2] = 2) 返回值: dp[n],即通过累积,dp[n]为爬到第n阶台阶的方式 改进: 因为dp只

    2024年02月03日
    浏览(22)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包