7-25 最长上升子序列
一个数的序列bi,当b1<b2<…<b
S
的时候,我们称这个序列是上升的。对于给定的一个序列(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)。
你的任务,就是对于给定的序列,求出最长上升子序列的长度。
输入格式:
输入的第一行是序列的长度N(1≤N≤20000)。第二行给出序列中的N个整数,这些整数的取值范围都在0到10000。
输出格式:
最长上升子序列的长度。
输入样例:
7
1 7 3 5 9 4 8
输出样例:
4
#include <iostream>
using namespace std;
int n,a[50],s[50][50];//s[i][j]
int f(int L,int R)
{
if(L==R)return 0;
if(s[L][R]>0)return s[L][R];
int t=0x3f3f3f3f,x;
for(int k=L;k<R;k++)
{
x=f(L,k)+f(k+1,R)+a[L-1]*a[R]*a[k];
if(x<t)
t=x;
}
return s[L][R]=t;
}
int main()
{
cin>>n;
for(int i=0;i<=n;i++)
cin>>a[i];
cout<<f(1,n);
return 0;
}