比赛 动态规划练习2 评测结果 AAAAAAAAAA
题目名称 最长上升子序列 最终得分 100
用户昵称 swttc 运行时间 0.004 s
代码语言 C++ 内存使用 0.32 MiB
提交时间 2017-03-28 19:25:00
显示代码纯文本
#include<iostream>
#include<cstdio>
using namespace std;
int f[1200],n,a[1200],maxn;
int main()
{
	freopen("lis1.in","r",stdin);
	freopen("lis1.out","w",stdout);
	scanf("%d",&n);
	for(int i=1;i<=n;i++)
	{
		scanf("%d",&a[i]);
	}
	for(int i=1;i<=n;i++)
	{
		maxn=0;
	 for(int j=1;j<=n;j++)
	 {
	 	if(a[i]>a[j])
	 	 maxn=max(maxn,f[j]);
	 }
	 f[i]=maxn+1;
   }
   maxn=0;
   for(int i=1;i<=n;i++) maxn=max(maxn,f[i]);
   printf("%d",maxn);
	return 0;
}