动态规划法
设长度为N的数组为{a0,a1, a2, …an-1),则假定包含aj的最长递增子序列中aj的位置为Lj,则Lj={ max(Li) + 1, i < j 且 ai < aj }。也就是说,我们需要遍历在 j 之前的所有位置 i (从 0 到 j - 1),找出满足条件的Li,求出max(Li)+1即为Lj的值。最后,我们遍历所有的 Lj(从 0 到 n - 1),找出最大值即为最大递增子序列。时间复杂度为O(N2)。
例题:合唱队
题目描述
计算最少出列多少位同学,使得剩下的同学排成合唱队形
说明:
N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形。
合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2,…,TK, 则他们的身高满足存在i(1<=i<=K)使得T1<T2<…<Ti-1Ti+1>…>TK。
你的任务是,已知所有N位同学的身高,计算最少需要几位