HDU 5842:Lweb and String (统计)

网友投稿 250 2022-08-30

HDU 5842:Lweb and String (统计)

Lweb and String

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Total Submission(s): 261    Accepted Submission(s): 174

Problem Description

S. Oneday, he decided to transform this string to a new sequence.  You need help him determine this transformation to get a sequence which has the longest LIS(Strictly Increasing).  You need transform every letter in this string to a new number. A is the set of letters of  S,  B is the set of natural numbers.  Every injection  f:A→B can be treat as an legal transformation.  For example, a String “aabc”,  A={a,b,c}, and you can transform it to “1 1 2 3”, and the LIS of the new sequence is 3.  Now help Lweb, find the longest LIS which you can obtain from  S. LIS: Longest Increasing Subsequence. (https://en.wikipedia.org/wiki/Longest_increasing_subsequence)

Input

T,(1≤T≤20). Then  T lines follow, the i-th line contains a string  S only containing the lowercase letters, the length of  S will not exceed  105.

Output

For each test case, output a single line "Case #x: y", where x is the case number, starting from 1. And y is the answer.

Sample Input

2 aabcc acdeaa

Sample Output

Case #1: 3 Case #2: 4

这道题的题目很长,并且很容易让人误以为是一个求最大上升子序列长度的问题,其实只是一个计算不同字符个数的问题,别小看这种问题哦!很轻松就会超时的。

AC代码:

#include#include#include#include#includeusing namespace std;char c[100005];int a[30];int main(){ int n; scanf("%d%*c",&n); for(int i=1; i<=n; i++) { gets(c); int s=0; memset(a,0,sizeof(a)); for(int j=0; j<(int)strlen(c); j++) { if(!a[c[j]-'a']) { a[c[j]-'a']=true; s++; } } printf("Case #%d: %d\n",i,s); } return 0;}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:终于不用再讲“营销神话”,海底捞关店300家,坑苦了谁?(海底捞门店利润)
下一篇:佩德里喜提2021年金童奖,上一个当选的巴萨球员是梅西!(2015年金球奖梅西中场身份入选)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~