算法训练营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;
    }
};
相关推荐
wlwhonest3 分钟前
最近公共祖先
算法
激昂~逐流8 分钟前
leetcode秋招冲刺 (专题16--18)
leetcode·哈希算法
钢铁男儿22 分钟前
Halcon支持向量机
算法·机器学习·支持向量机
**K36 分钟前
C++ 智能指针使用不当导致内存泄漏问题
开发语言·c++·算法
Leo-Peng39 分钟前
辐射神经场算法——Instant-NGP / Mipi-NeRF 360 / 3D Gaussian Splatting
算法·nerf·3d gaussian
菌菌巧乐兹40 分钟前
C# 快速排序算法的详细讲解
算法·排序算法
TechQuester1 小时前
解决GPT-4o耗电难题!DeepMind新算法训练效率提升13倍,能耗降低10倍!
java·c++·人工智能·python·算法·chatgpt
Espresso Macchiato1 小时前
Leetcode 3213. Construct String with Minimum Cost
动态规划·leetcode hard·trie树·leetcode 3213·leetcode周赛405
XSTIT1 小时前
数据结构--二叉树相关题2(OJ)
数据结构·算法
观鉴词recommend1 小时前
【c++刷题笔记-动态规划】day32: 509. 斐波那契数 、 70. 爬楼梯 、 746. 使用最小花费爬楼梯
c++·笔记·算法·leetcode·动态规划