最长上升子序列(LIS)

最长上升子序列(LIS)

朴素dp(O( n 2 n^2 n2))

  • 状态表示:
    • 集合dp:所有满足上升条件的元素集
    • 属性:cnt,dp[i]表示以i结尾的上升子序列长度,init(dp)=1
  • 状态计算:
    • i为当前工作区间尾指针,j为当前工作区间工作指针
    • 不选i:a[j]>a[i],无法满足最优解,不选
    • 选i:a[j]<a[i],满足上升条件,可选
      • dp[i]的结果转移自dp[j],因此转移方程为 d p [ i ] = m a x ( d p [ i ] , d p [ j ] + 1 ) dp[i]=max(dp[i],dp[j]+1) dp[i]=max(dp[i],dp[j]+1),当 d p [ i ] = d p [ j ] + 1 dp[i]=dp[j]+1 dp[i]=dp[j]+1时,说明a[i]已选,否则证明a[j]包含在之前已选的子集中
cpp 复制代码
extern vector<int>v(n),dp(n,1);
int dp(){
	for(int i=0;i<n;i++)
        for(int j=0;j<i;j++)
            if(v[j]<v[i])//选v[i]
                dp[i]=max(dp[i],dp[j]+1);
    return *max_element(dp.begin(),dp.end());
}

LCS求解LIS(O( n 2 n^2 n2))

思路:将序列排序,两序列的LCS即为原序列的LIS

贪心+二分(O( n log ⁡ n n\log n nlogn))

相关推荐
kim565930 分钟前
excel版数独游戏(已完成)
算法·游戏·excel·数独
cv君1 小时前
【AI最前线】DP双像素sensor相关的AI算法全集:深度估计、图像去模糊去雨去雾恢复、图像重建、自动对焦
算法
Ocean☾1 小时前
C语言-详细讲解-P1217 [USACO1.5] 回文质数 Prime Palindromes
c语言·数据结构·算法
沐泽Mu1 小时前
嵌入式学习-C嘎嘎-Day08
开发语言·c++·算法
Non importa1 小时前
汉诺塔(hanio)--C语言函数递归
c语言·开发语言·算法·学习方法
ac-er88882 小时前
PHP 二分法查找算法
开发语言·算法·php
Choshim-2 小时前
7-9 求无向图连通分量的数量
数据结构·算法·深度优先
Eric.Lee20212 小时前
数据集-目标检测系列- 昙花(昙花一现) 检测数据集 epiphyllum >> DataBall
算法·yolo·目标检测·计算机视觉·昙花一现·昙花检测
淀粉肠kk3 小时前
【数据结构】二叉树(2)
数据结构·算法
总是学不会.3 小时前
【贪心算法】绿洲之旅:最少次数补给探索
java·算法·intellij-idea