题目描述:
求一个字符串的最长递增子序列的长度
如:dabdbf最长递增子序列就是abdf,长度为4
如: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; }