代码随想录day52

300最长递增子序列

cpp 复制代码
class Solution {
public:
    int lengthOfLIS(vector<int>& nums) 
    {
        int piles = 0;    // 牌堆数初始化为 0
        vector<int> top(nums.size());   // 牌堆数组 top
        for (int i = 0; i < nums.size(); i++) 
        {
            int poker = nums[i];  
            int left = 0, right = piles;   
            while (left < right) 
            {
                int mid = (left + right) / 2; 
                if (top[mid] < poker) 
                {
                    left = mid + 1;
                } else {
                    right = mid;
                }
            }
            if (left == piles) piles++;
            top[left] = poker;
        }
        // 牌堆数就是 LIS 长度
        return piles;
    }
};

674最长连续递增子序列

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

718最长重复子数组

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;
    }
};
相关推荐
冠位观测者27 分钟前
【Leetcode 热题 100】208. 实现 Trie (前缀树)
数据结构·算法·leetcode
小王爱吃月亮糖2 小时前
C++的23种设计模式
开发语言·c++·qt·算法·设计模式·ecmascript
IT猿手3 小时前
最新高性能多目标优化算法:多目标麋鹿优化算法(MOEHO)求解LRMOP1-LRMOP6及工程应用---盘式制动器设计,提供完整MATLAB代码
开发语言·算法·matlab·智能优化算法·多目标算法
kittygilr3 小时前
matlab中的cell
开发语言·数据结构·matlab
花心蝴蝶.4 小时前
Map接口 及其 实现类(HashMap, TreeMap)
java·数据结构
InfiSight智睿视界4 小时前
AI 技术,让洗护行业焕然「衣」新
人工智能·算法
程序员一诺4 小时前
【机器学习】嘿马机器学习(算法篇)第11篇:决策树算法,学习目标【附代码文档】
人工智能·python·算法·机器学习
Evand J5 小时前
平方根无迹卡尔曼滤波(SR-UKF)算法,用于处理三维非线性状态估计问题
算法
taoyong0015 小时前
代码随想录算法训练营第十五天-二叉树-110.平衡二叉树
数据结构·算法
-芒果酱-5 小时前
k-Means聚类算法 HNUST【数据分析技术】(2025)
算法·kmeans·聚类