算法训练营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;
    }
};
相关推荐
你撅嘴真丑9 小时前
第九章-数字三角形
算法
uesowys9 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder9 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮9 小时前
AI 视觉连载1:像素
算法
智驱力人工智能9 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥10 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风10 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風11 小时前
8.1 PFH&&FPFH
图像处理·算法
NEXT0611 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
代码游侠11 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法