代码随想录训练营第43天|二维dp

300. 最长递增子序列

cpp 复制代码
class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
        int n=nums.size();
        int max_len=1;
        vector<int> dp(n,1);
        for(int i=1; i<n; i++){
            for(int j=0; j<i; j++){
                if(nums[j]<nums[i])
                    dp[i]=max(dp[i],dp[j]+1);
            }
            max_len=max(max_len,dp[i]);
        }
        return max_len;
    }
};

dp[i]:以下标i为终点的递增子序列的最大长度

转移方程:可由前置的任何一个j转移而来(满足递增的情况下),累计最大得到dp[i],对所有dp取最大值得到全局最大,注意最长递增子序列不一定要取到末尾元素,可能在中间最大。

674. 最长连续递增序列

cpp 复制代码
class Solution {
public:
    int findLengthOfLCIS(vector<int>& nums) {
        int n = nums.size();
        int max_len=1;
        vector<int> dp(n, 1);
        for (int i = 1; i < n; i++) {
            if (nums[i - 1] < nums[i])
                dp[i] = dp[i - 1] + 1;
            max_len=max(max_len,dp[i]);
        }
        return max_len;
    }
};

和上题的差异在"连续",意味着只能从上一个元素(i-1)转移而来,而不用遍历所有前置节点。

718. 最长重复子数组

cpp 复制代码
class Solution {
public:
    int findLength(vector<int>& nums1, vector<int>& nums2) {
        nums1.insert(nums1.begin(),-1);
        nums2.insert(nums2.begin(),-1);
        int n1=nums1.size(), n2=nums2.size(), max_len=0;
        vector<vector<int>> dp(n1,vector<int>(n2,0));
        for(int i=1; i<n1; i++){
            for(int j=1; j<n2; j++){
                if(nums1[i]==nums2[j]){
                    dp[i][j]=dp[i-1][j-1]+1;
                }
                max_len=max(max_len,dp[i][j]);
            }
        }
        return max_len;
    }
};

两个输入,二维dp,定义dp[i][j]:使用nums1[i]及nums2[j]结尾的重复子数组的最大长度

转移方程:

1.如果结尾元素相等,则可由删除结尾的子串的最长重复子数组转移而来

2.如果结尾元素不等,则一定为0

相关推荐
乌萨奇也要立志学C++7 分钟前
【洛谷】贪心专题之推公式 用 “相邻元素交换” 推导最优规则
c++·算法
ULTRA??19 分钟前
STL deque 的详细特征
c++·算法
yongui4783421 分钟前
MATLAB 二维方腔自然对流 SIMPLE 算法
人工智能·算法·matlab
循着风31 分钟前
环形子数组的最大和
数据结构·算法·leetcode
CoovallyAIHub32 分钟前
如何让AI的数据标注“火眼金睛”?人机协同才是可靠途径
深度学习·算法·计算机视觉
wa的一声哭了34 分钟前
拉格朗日插值
人工智能·线性代数·算法·机器学习·计算机视觉·自然语言处理·矩阵
gongfuyd36 分钟前
傅里叶变换、拉普拉斯变换、Z 变换的定义及关系
算法·机器学习·概率论
珂朵莉MM38 分钟前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第三赛季--前五题总结
人工智能·算法
啊阿狸不会拉杆38 分钟前
《数字图像处理》第2章-数字图像基础
图像处理·python·算法·计算机视觉·数字图像处理
云飞云共享云桌面40 分钟前
云飞云智能共享云桌面:企业PLM/ERP/MES等系统管理的革新方案
运维·服务器·网络·算法·性能优化