定义数组b[]用来存放a[]中每个数的上升子序列的个数,找出b[]中最大值。
#include
using namespace std;
const int maxn=1e5+5;
const int INF=1e9+5;
int dp[maxn],v[maxn],d[maxn];
freopen("in.txt", "r", stdin);
int n;
while(scanf("%d",&n)!=EOF){
v[0]=0;
for(int i=0;i
scanf("%d",d+i);
v[i]=INF;
//cout<<v<<endl;
int f=lower_bound(v,v+i+1,d[i])-v;///lower_bound(v,v+i+1,d[i])在0到i之间查找第一个大于d[i]的下标
dp[i]=f+1;
v[f]=d[i];
}
//cout<<endl;
int ans=-1;
for(int i=0;i
ans=max(ans,dp[i]);
printf("%d\n",ans);
}
return 0;
}