最长上升子序列(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))

相关推荐
blammmp1 小时前
算法专题十九:记忆化搜索(暴搜->记忆化搜索)
算法·深度优先·记忆化搜索
MicroTech20252 小时前
边缘智能的创新:MLGO微算法科技推出基于QoS感知的边缘大模型自适应拆分推理编排技术
科技·算法·ai
王哈哈^_^3 小时前
【数据集】【YOLO】目标检测游泳数据集 4481 张,溺水数据集,YOLO河道、海滩游泳识别算法实战训练教程。
人工智能·算法·yolo·目标检测·计算机视觉·分类·视觉检测
巴里巴气3 小时前
第73题 矩阵置零
线性代数·算法·矩阵
voice6704 小时前
密码学实验二
算法·密码学·哈希算法
Blossom.1185 小时前
把AI“编”进草垫:1KB决策树让宠物垫自己报「如厕记录」
java·人工智能·python·算法·决策树·机器学习·宠物
寂静山林5 小时前
UVa 10989 Bomb Divide and Conquer
算法
兮山与5 小时前
算法23.0
算法
共享家95276 小时前
数独系列算法
算法·深度优先
liebe1*17 小时前
C语言程序代码(四)
c语言·数据结构·算法