请编写程序, 找出一段给定文字中出现最频繁的那个英文字母.
输入格式:
输入在一行中给出一个长度不超过 1000 的字符串. 字符串由 ASCII 码表中任意可见字符及空格组成, 至少包含 1 个英文字母, 以回车结束 (回车不算在内).
输出格式:
在一行中输出出现频率最高的那个英文字母及其出现次数, 其间以空格分隔. 如果有并列, 则输出按字母序最小的那个字母. 统计时不区分大小写, 输出小写字母.
输入样例:
This is a simple TEST. There ARE numbers and other symbols 1&2&3...........
输出样例:
- e 7
- #include<iostream>
- #include<string>
- using namespace std;
- int main()
- {
- int n[205]={0};
- string str;
- getline(cin,str);
- for(int i=0;i<str.length();i++)
- {
- if(str[i]!=' ')
- {
- if((str[i]>='A'&&str[i]<='Z')||(str[i]>='a'&&str[i]<='z'))
- if(str[i]>='A'&&str[i]<='Z')
- n[str[i]+32]++;
- else n[str[i]]++;
- }
- }
- int max=0;
- char k=0;
- for(int i=0;i<205;i++)
- if(max<n[i])
- {
- max=n[i];
- k=i;
- }
- cout<<k<<" "<<max;
- return 0;
- }
来源: http://www.bubuko.com/infodetail-3289819.html