• 1.摘要
  • 2.基本信息
  • 3.Pascal代码
  • 4.O(n^2)算法分析

lis算法

LIS(Longest Increasing Subsequence)最长上升(不下降)子序列,有两种算法复杂度为O(n*logn)和O(n^2)。在上述算法中,若使用朴素的顺序查找在D1..Dlen查找,由于共有O(n)个元素需要计算,每次计算时的复杂度是O(n),则整个算法的时间复杂度为O(n^2),与原来算法相比没有任何进步。但是由于D的特点(2),在D中查找时,可以使用二分查找高效地完成,则整个算法时间复杂度下降为O(nlogn),有了非常显著的提高。需要注意的是,D在算法结束后记录的并不是一个符合题意的最长上升子序列!算法还可以扩展到整个最长子序列系列问题。

基本信息

  • 中文名

    LIS算法

  • 外文名

    Longest Increasing Subsequence

  • 复杂度

    O(n*logn)和O(n^2)

  • 特点

    单调不上升

Pascal代码

program Project1;

var a,x:array[1..10000]of longint;

i,j,sum,n:longint;

function min(s:longint):longint;

var l,r,t:longint;

begin

l:=1;

r:=sum;

while l<r do

begin

t:=(l+r)div 2;

if s>x[t]then l:=t+1

else r:=t;

while x[l]=s do inc(l);

end;

exit(l);

end;

begin readln(n);