题目描述:

求一个字符串的最长递增子序列的长度
如: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;
}