day37-数据结构力扣

300.最长递增子序列

题目链接

思路

1. dp 数组及下标含义

dp[i]:以 nums[i] 结尾的最长严格递增子序列长度

2. 递推公式

遍历 j∈[0,i−1]:若 nums[i]>nums[j](严格递增)dp[i]=max(dp[i], dp[j]+1)

3. 数组初始化

每个元素自身单独构成子序列dp[i]=1

4. 遍历顺序

  • 外层:i 从 1 到末尾

  • 内层:j 从 0 到 i−1

5. 结果

整个 dp 数组的最大值

提交

python 复制代码
class Solution:
    def lengthOfLIS(self, nums: List[int]) -> int:
        n = len(nums)
        # dp[i]:以nums[i]结尾的最长严格递增子序列长度
        dp = [1] * n
        
        # 遍历每个位置i
        for i in range(n):
            # 遍历i前面所有元素j
            for j in range(i):
                # 满足严格递增,可拼接
                if nums[i] > nums[j]:
                    dp[i] = max(dp[i], dp[j] + 1)
        # 全局最大值即为答案
        return max(dp)

674. 最长连续递增序列

题目链接 674. 最长连续递增序列 - 力扣(LeetCode)

思路

1. dp 数组含义

dp[i]:以 nums[i] 结尾的最长连续严格递增子数组长度

2. 递推公式

如果满足连续严格递增:nums[i]>nums[i−1],dp[i]=dp[i−1]+1

否则:dp[i]=1

3. 初始化

每个元素自身长度为 1:dp[i]=1

4. 遍历顺序

从左到右,i 从 1 向后遍历

5. 最终结果

dp 数组最大值

关键区分

最长递增子序列 LIS:不连续,两层循环 O(n2)

最长连续递增子序列:必须连续,一层循环 O(n)

提交

python 复制代码
class Solution:
    def findLengthOfLCIS(self, nums: List[int]) -> int:
        n = len(nums)
        # dp[i]:以nums[i]结尾的最长连续递增子数组长度
        dp = [1] * n
        
        for i in range(1, n):
            # 连续严格递增
            if nums[i] > nums[i - 1]:
                dp[i] = dp[i - 1] + 1
            # 不满足则保持dp[i]=1,单独重新开始
        
        return max(dp)

718. 最长重复子数组

题目链接

思路

1. dp 数组含义

dp[i][j]:表示 nums1 前 i 个元素nums2 前 j 个元素 中,最长公共连续子数组的长度

2. 递推公式

  • 如果 nums1[i-1] == nums2[j-1]:说明当前两个数字相同,可以接在上一段后面

  • dp[i][j] = dp[i-1][j-1] + 1

  • 如果不相等:连续中断,dp[i][j] = 0

3. 初始化

dp[0][j] = 0

dp[i][0] = 0(空数组没有公共子数组)

4. 遍历顺序

两层循环:

  • 外层:遍历 nums1

  • 内层:遍历 nums2

5. 结果

遍历过程中记录 dp 数组的最大值

提交

python 复制代码
class Solution:
    def findLength(self, nums1: List[int], nums2: List[int]) -> int:
        m = len(nums1)
        n = len(nums2)
        
        # dp[i][j]:nums1前i个,nums2前j个,最长公共连续子数组长度
        dp = [[0] * (n + 1) for _ in range(m + 1)]
        res = 0  # 记录最大长度
        
        for i in range(1, m + 1):
            for j in range(1, n + 1):
                # 当前数字相等,连续长度+1
                if nums1[i-1] == nums2[j-1]:
                    dp[i][j] = dp[i-1][j-1] + 1
                    # 更新最大值
                    res = max(res, dp[i][j])
                # 不相等时 dp[i][j] 默认为 0,不用处理
        
        return res
相关推荐
啦啦啦_99991 小时前
1. 逻辑回归
算法·机器学习·逻辑回归
fengenrong2 小时前
20260429
c++·算法
南宫萧幕2 小时前
Python与Simulink联合仿真:基于DQN的HEV能量管理策略建模与全链路排雷实战
开发语言·人工智能·python·算法·机器学习·matlab·控制
apollowing2 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(优)
算法·启发式算法·web app
liuyao_xianhui2 小时前
进程概念与进程状态_Linux
linux·运维·服务器·数据结构·c++·哈希算法·宽度优先
如君愿2 小时前
考研复习 Day 26 | 习题--计算机网络第三章(数据链路层 下)、数据结构 多维数组与广义表
数据结构·计算机网络·考研·记录考研
bqq198610262 小时前
MySQL分库分表
数据结构·mysql
迷途之人不知返3 小时前
List的模拟实现
数据结构·c++·学习·list
Chat_zhanggong3453 小时前
主推NT98336BG作用有哪些?
嵌入式硬件·算法