算法训练营day56

题目1:300. 最长递增子序列 - 力扣(LeetCode)

复制代码
class Solution {
public:
    int lengthOfLIS(vector<int>& nums) {
        // dp数组含义是第i个数的严格递增子序列的长度
        // 内层的递推公式就是 取 0 到 i - 1之间最大的dp数组 然后 + 1
        vector<int> dp(nums.size(), 1);
        int reslut = 1;
        for(int i = 1;i < nums.size();i++) {
            for(int j = 0;j < i;j++) {
                if(nums[i] > nums[j]) {
                    dp[i] = max(dp[i], dp[j] + 1);
                }
            }
            reslut = max(reslut, dp[i]);
        }
        return reslut;
    }
};

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

暴力解法:

复制代码
class Solution {
public:
    int findLengthOfLCIS(vector<int>& nums) {
        int reslut = 1;
        for(int i = 0;i < nums.size();i++) {
            int len = 1;
            for(int j = i;j < nums.size() - 1;j++) {
                if(nums[j + 1] > nums[j]) {
                    len++;
                }else break;
            }
            reslut = max(reslut, len);
        }
        return  reslut;
    }
};

动态规划

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

题目3:718. 最长重复子数组 - 力扣(LeetCode)

复制代码
class Solution {
public:
    int findLength(vector<int>& nums1, vector<int>& nums2) {
        vector<vector<int>> dp(nums1.size() + 1, vector<int>(nums2.size() + 1));
        int reslut = 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;
                }
                reslut = max(reslut, dp[i][j]);
            }
        }
        return reslut;
    }
};
相关推荐
Fanxt_Ja1 小时前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
侃侃_天下1 小时前
最终的信号类
开发语言·c++·算法
茉莉玫瑰花茶1 小时前
算法 --- 字符串
算法
博笙困了1 小时前
AcWing学习——差分
c++·算法
NAGNIP1 小时前
认识 Unsloth 框架:大模型高效微调的利器
算法
NAGNIP1 小时前
大模型微调框架之LLaMA Factory
算法
echoarts1 小时前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
Python技术极客1 小时前
一款超好用的 Python 交互式可视化工具,强烈推荐~
算法
徐小夕1 小时前
花了一天时间,开源了一套精美且支持复杂操作的表格编辑器tablejs
前端·算法·github
小刘鸭地下城2 小时前
深入浅出链表:从基础概念到核心操作全面解析
算法