题目要求:
一个数的序列bi,当b1 < b2 < ... < bS的时候,我们称这个序列是上升的。对于给定的一个序列(a1, a2, ..., aN),我们可以得到一些上升的子序列(ai1, ai2, ..., aiK),这里1 <= i1 < i2 < ... < iK <= N。比如,对于序列(1, 7, 3, 5, 9, 4, 8),有它的一些上升子序列,如(1, 7), (3, 4, 8)等等。这些子序列中最长的长度是4,比如子序列(1, 3, 5, 8)。求最长上升子序列的长度。
题目思路:
定义数组a,a[i]代表包含第i个值的子序列的元素个数,利用双重循环求出包含第k个值的最长子序列的值。
细节处理:
找出状态转移方程:max(1)=1,max(k)=Max{max(i):1<i<k且ai<ak且开不等于1}+1。
#include<bits/stdc++.h>
using namespace std;
int main()
{ int a[1005];
int b[1005];
int i,j,N;
cin>>N;
for(i=1;i<=N;i++)
cin>>b[i];
a[1]=1;
for(i=2;i<=N;i++)
{
int n=0;
for(j=1;j<i;j++)
{
if(b[i]>b[j])
{
if(n<a[j])
n=a[j];
}
}a[i]=n+1;
}
int M=-1;
for(i=1;i<=N;i++)
if(M<a[i])
M=a[i];
cout<<M<<endl;
return 0;
}