代码随想录第43天

300.最长递增子序列

python 复制代码
# Dynamic programming.
class Solution:
    def lengthOfLIS(self, nums: List[int]) -> int:
        if not nums: return 0
        dp = [1] * len(nums)
        for i in range(len(nums)):
            for j in range(i):
                if nums[j] < nums[i]: # 如果要求非严格递增,将此行 '<' 改为 '<=' 即可。
                    dp[i] = max(dp[i], dp[j] + 1)
        return max(dp)

674. 最长连续递增序列

python 复制代码
class Solution:
    def findLengthOfLCIS(self, nums: List[int]) -> int:
        l = 0  # 起点
        r = 0  # 终点
        maxLen = 0  # 待返回的最长长度

        while r < len(nums):
            if r == l or nums[r - 1] < nums[r]:  # 保持递增
                maxLen = max(maxLen, r - l + 1)  # 比较取大
                r += 1  # 终点前进
            else:  # 递增中断
                l = r  # 更新起点

        return maxLen

718. 最长重复子数组

python 复制代码
class Solution:
    def findLength(self, A, B):
        m, n = len(A), len(B)
        ans = 0
        dp = [[0 for _ in range(n + 1)] for _ in range(m + 1)]
        for i in range(1, m + 1):
            for j in range(1, n + 1):
                if A[i - 1] == B[j - 1]:
                    dp[i][j] = dp[i - 1][j - 1] + 1
                    ans = max(ans, dp[i][j])
        return ans
相关推荐
智航GIS11 小时前
10.7 pyspider 库入门
开发语言·前端·python
副露のmagic11 小时前
更弱智的算法学习 day25
python·学习·算法
hudawei99612 小时前
Flask 与 FastAPI 对比分析
python·flask·fastapi
寻星探路12 小时前
【Python 全栈测开之路】Python 基础语法精讲(一):常量、变量与运算符
java·开发语言·c++·python·http·ai·c#
智航GIS12 小时前
10.5 PyQuery:jQuery 风格的 Python HTML 解析库
python·html·jquery
小兔崽子去哪了12 小时前
机器学习,梯度下降,拟合,正则化,混淆矩阵
python·机器学习
缘友一世12 小时前
PyCharm连接autodl平台服务(python解释器&jupyter lab)
python·jupyter·pycharm
a程序小傲13 小时前
得物Java面试被问:方法句柄(MethodHandle)与反射的性能对比和底层区别
java·开发语言·spring boot·后端·python·面试·职场和发展
华研前沿标杆游学13 小时前
2026走进滕讯:小游戏×大模型产业交流记
python
_codemonster13 小时前
计算机视觉入门到实战系列(八)Harris角点检测算法
python·算法·计算机视觉