目录
牛客_计算某字符出现次数
解析代码
首先,字符串中包含有空格,因此我们使用 gets 函数获取一行数据,而不用 scanf ,因为 scanf 函数会默认以空格截断输入作为输入的结束。
其次,因为在计算字符出现次数中,要求是不区分大小写的,因此在处理过程中,如果输入的是小写字母,则计数不但要加上小写字母的计数,还要加上大写字母的计数,反之大写字母也是同样如此,而在 ascii 表中,大写字母和小写字母的差值是 32 ( 'a'的ascii值是97 ; 'A'的ascii值是65 )
最后,实现思路,因为 ascii字符 只有 128 个,他们的实际存储是 0~127 ,那么我们只需要定义一个具有 128 个整形元素的数组,第 0 号下标位置存放 0 对应的 ascii字符出现次数, 1 号下标位置存放 1 对应的 ascii字符 的次数....以此类推,数组每个位置存放的就是对应 ascii字符出现的次数。最终以指定字符为下标获取它出现的次数进行打印。
#include <cctype>
#include <iostream>
#include <string>
using namespace std;
int main()
{
string str;
getline(cin, str);
char c;
cin >> c;
if (islower(c)) // 全部小写字母转大写
{
c -= 32;
}
int cnt = 0;
for (auto& e : str)
{
if (islower(e))
e -= 32;
if (e == c)
++cnt;
}
cout << cnt;
return 0;
}