Polycarp loves lowercase letters and dislikes uppercase ones. Once he got a string s consisting only of lowercase and uppercase Latin letters.
Let A be a set of positions in the string. Let's call it pretty if following conditions are met:
- letters on positions from A in the string are all distinct and lowercase;
- there are no uppercase letters in the string which are situated between positions from A (i.e. there is no such j that s[j] is an uppercase letter, and a1 < j < a2 for some a1 and a2 from A).
Write a program that will determine the maximum number of elements in a pretty set of positions.
The first line contains a single integer n (1 ≤ n ≤ 200) — length of string s.
The second line contains a string s consisting of lowercase and uppercase Latin letters.
Print maximum number of elements in pretty set of positions for string s.
11 aaaaBaabAbA
2
12 zACaAbbaazzC
3
3 ABC
0
In the first example the desired positions might be 6 and 8 or 7 and 8. Positions 6 and 7 contain letters 'a', position 8 contains letter 'b'. The pair of positions 1 and 8 is not suitable because there is an uppercase letter 'B' between these position.
In the second example desired positions can be 7, 8 and 11. There are other ways to choose pretty set consisting of three elements.
In the third example the given string s does not contain any lowercase letters, so the answer is 0.
昨天看人家都把这题做出来了,尴尬的我干着急,实在是没读懂题,题目这两句英文说的是真的不清楚啊,这么多年英语怎么学的。好吧,题意一句话,求连续的小写字母里字母种类最多是多少。
代码如下:
#include<iostream>
#include<string>
#include<map>
using namespace std;
int main()
{
int n;
map<char, int>vis;
string str;
while(cin>>n)
{
cin>>str;
int ans=0;
int temp=0;
vis.clear();
for(int i=0; i<n; i++)
{
if(str[i]>='A' && str[i]<='Z')
{
if(ans<temp)
ans=temp;
vis.clear();
temp=0;
}
else if(str[i]>='a' && str[i]<='z')
{
if(vis[str[i]]==0)
temp++;
vis[str[i]]=1;
}
}
if(ans<temp)
ans=temp;
cout<<ans<<endl;
}
return 0;
}