算法训练营Day52(动态规划13)

300.最长递增子序列 力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

提醒

今天开始正式子序列系列,本题是比较简单的,感受感受一下子序列题目的思路。

class Solution:
    def lengthOfLIS(self, nums: List[int]) -> int:
        if len(nums) <= 1:
            return len(nums)
        dp = [1] * len(nums)
        result = 1
        for i in range(1, len(nums)):
            for j in range(0, i):
                if nums[i] > nums[j]:
                    dp[i] = max(dp[i], dp[j] + 1)
            result = max(result, dp[i]) #取长的子序列
        return result

674. 最长连续递增序列 力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

提醒

本题相对于300.最长递增子序列 最大的区别在于“连续”。 先尝试自己做做,感受一下区别  

class Solution:
    def findLengthOfLCIS(self, nums: List[int]) -> int:
        if len(nums) == 0:
            return 0
        result = 1
        dp = [1] * len(nums)
        for i in range(len(nums)-1):
            if nums[i+1] > nums[i]: #连续记录
                dp[i+1] = dp[i] + 1
            result = max(result, dp[i+1])
        return result

 

718. 最长重复子数组 力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

提醒

较有难度,要使用二维dp数组了,子数组是求连续且重复

class Solution:
    def findLength(self, nums1: List[int], nums2: List[int]) -> int:
        # 创建一个二维数组 dp,用于存储最长公共子数组的长度
        dp = [[0] * (len(nums2) + 1) for _ in range(len(nums1) + 1)]
        # 记录最长公共子数组的长度
        result = 0

        # 遍历数组 nums1
        for i in range(1, len(nums1) + 1):
            # 遍历数组 nums2
            for j in range(1, len(nums2) + 1):
                # 如果 nums1[i-1] 和 nums2[j-1] 相等
                if nums1[i - 1] == nums2[j - 1]:
                    # 在当前位置上的最长公共子数组长度为前一个位置上的长度加一
                    dp[i][j] = dp[i - 1][j - 1] + 1
                # 更新最长公共子数组的长度
                if dp[i][j] > result:
                    result = dp[i][j]

        # 返回最长公共子数组的长度
        return result

 拓展dp定义

其定义有两种含义,仔细对比这两种的区别

相关推荐

  1. 算法训练Day52动态规划13

    2024-01-27 01:02:01       29 阅读
  2. 算法训练Day50动态规划11

    2024-01-27 01:02:01       41 阅读
  3. 算法训练Day53动态规划14

    2024-01-27 01:02:01       33 阅读
  4. 算法训练Day56动态规划16

    2024-01-27 01:02:01       31 阅读
  5. 算法训练Day57动态规划17

    2024-01-27 01:02:01       36 阅读
  6. 代码随想录算法训练day54|第九章 动态规划part15

    2024-01-27 01:02:01       22 阅读
  7. 算法训练Day49(动态规划10

    2024-01-27 01:02:01       41 阅读
  8. 算法训练day47,动态规划15

    2024-01-27 01:02:01       21 阅读
  9. 算法训练day44(补),动态规划12

    2024-01-27 01:02:01       18 阅读
  10. 算法训练Day40(动态规划

    2024-01-27 01:02:01       34 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-27 01:02:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-27 01:02:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-27 01:02:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-27 01:02:01       20 阅读

热门阅读

  1. 网络协议基础

    2024-01-27 01:02:01       29 阅读
  2. 2024-01-26 成长-复盘

    2024-01-27 01:02:01       36 阅读
  3. 什么是迁移学习

    2024-01-27 01:02:01       27 阅读
  4. Python技术栈 —— 一种超时LRU的实现方式

    2024-01-27 01:02:01       41 阅读
  5. ModuleNotFoundError: No module named ‘half_json‘

    2024-01-27 01:02:01       43 阅读
  6. 工厂方法模式-C#实现

    2024-01-27 01:02:01       38 阅读