20240412-算法复习打卡day52||● 300.最长递增子序列 ● 674. 最长连续递增序列 ● 718. 最长重复子数组

300.最长递增子序列

从前往后遍历即可

cpp 复制代码
class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
        if (nums.size() <= 1) return nums.size();
        vector<int> dp(nums.size(), 1);
        int result = 0;
        for (int i = 1; i < nums.size(); i++) {
            for (int j = 0; j < i; j++) {
                if (nums[i] > nums[j]) dp[i] = max(dp[j] + 1, dp[i]);
            }
            if (dp[i] > result) result = dp[i];
        }
        return result;
    }
};
674. 最长连续递增序列

DP

cpp 复制代码
class Solution {
public:
    int findLengthOfLCIS(vector<int>& nums) {
        if (nums.size() == 0) return 0;
        int result = 1;
        vector<int> dp(nums.size(), 1);
        for (int i = 1; i < nums.size(); i++) {
            if (nums[i] > nums[i - 1]) {
                dp[i] = dp[i - 1] + 1;
            }
            if (dp[i] > result) result = dp[i];
        }
        return result;
    }
};
贪心
cpp 复制代码
class Solution {
public:
    int findLengthOfLCIS(vector<int>& nums) {
        if (nums.size() == 0) return 0;
        int result = 1;
        int count = 1;
        for (int i = 1; i < nums.size(); i++) {
            if (nums[i] > nums[i - 1]) {
                count++;
            } else {
                count = 1;
            }
            if (count > result) result = count;
        }
        return result;
    }
};
718. 最长重复子数组

nums1和nums2匹配上之后,dp数组状态只能由其左上角推出来

cpp 复制代码
class Solution {
public:
    int findLength(vector<int>& nums1, vector<int>& nums2) {
        vector<vector<int>> dp(nums1.size() + 1, vector<int>(nums2.size() + 1, 0));
        int result = 0;
        for (int i = 1; i <= nums1.size(); i++) {
            for (int j = 1; j <= nums2.size(); j++) {
                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;
    }
};
相关推荐
Lris-KK19 分钟前
【Leetcode】高频SQL基础题--1164.指定日期的产品价格
sql·leetcode
GalaxyPokemon20 分钟前
LeetCode - 1089. 复写零
数据结构
失散1322 分钟前
分布式专题——1.2 Redis7核心数据结构
java·数据结构·redis·分布式·架构
Moonbit1 小时前
月报Vol.03: 新增Bitstring pattern支持,构造器模式匹配增强
后端·算法·github
快手技术1 小时前
多模态大模型Keye-VL-1.5发布!视频理解能力更强!
算法
薛定谔的算法1 小时前
JavaScript数组操作完全指南:从基础到高级
前端·javascript·算法
可爱的小小小狼1 小时前
算法:位运算
算法
zzzsde2 小时前
【数据结构】强化训练:从基础到入门到进阶(1)
数据结构
VisionPowerful2 小时前
九.弗洛伊德(Floyd)算法
算法·c#
可爱的小小小狼2 小时前
算法:哈希表
redis·算法·散列表