线代复习完了,完结撒花!!!!!!!高数英语大物还等着呢
最近做的都是水题,这么水更是不是对不起自己??管他呢
节省时间,赶紧麻溜的
请编写程序,找出一段给定文字中出现最频繁的那个英文字母。
输入格式:
输入在一行中给出一个长度不超过 1000 的字符串。字符串由 ASCII 码表中任意可见字符及空格组成,至少包含 1 个英文字母,以回车结束(回车不算在内)。
输出格式:
在一行中输出出现频率最高的那个英文字母及其出现次数,其间以空格分隔。如果有并列,则输出按字母序最小的那个字母。统计时不区分大小写,输出小写字母。
这道题很水了,但是一不留神还是在编写上会有点漏洞。
#include <cstdio>
#include <string>
#include <iostream>
using namespace std;
int symbols[256] = {0};
string input;
int main()
{
getline(cin, input);
for (int i = 0; i < input.length(); i++)
{
if (input[i] >= 'A' && input[i] <= 'Z')
{
symbols[input[i] + 32]++;
}
else
{
symbols[input[i]]++;
}
}
int max = -1;
char character;
for (int i = 'a'; i <= 'z'; i++)
{
if (symbols[i] > max)
{
max = symbols[i];
character = (char) i;
}
}
printf("%c %d" , character , max);
return 0 ;
}
没什么可解释的,只要学得了通过ASCII制造散列表,就没啥担心的。
有一点,就是在编写的时候,就会不知不觉之间把
里面的input[i]写成i....
这个低级错误我觉得值得一写,因为类似的错误,我犯了不止一次了/手动耸肩
今天课代表觉得我太水了,就不搭理我并且朝我吐了口痰
886~~~