题目描述:
求一个字符串的最长递增子序列的长度
如:dabdbf最长递增子序列就是abdf,长度为4
输入描述:
第一行一个整数0<n<20,表示有n个字符串要处理 随后的n行,每行有一个字符串,该字符串的长度不会超过10000
输出描述:
输出字符串的最长递增子序列的长度
样例输入:
复制
3
aaa
ababc
abklmncdefg
样例输出:
1
3
7
可以用求数字(LIS)的方法;
#include<iostream>
#include<algorithm>
#include<climits>
#include<cstring>
using namespace std;
char a[12000];
char dp[12000];
int main(){
int n,m;
cin>>n;
while(n--){
cin.clear();
cin>>a;
m=strlen(a);
fill(dp,dp+m,CHAR_MAX);
for(int i=0;i<m;i++){
*lower_bound(dp,dp+m,a[i])=a[i];
}
cout<<lower_bound(dp,dp+m,CHAR_MAX)-dp<<endl;
}
return 0;
}