【以下回答由 GPT 生成】
我可以使用一个大小为26的数组来统计每个字母出现的次数,数组的索引代表字母的ASCII码减去小写字母"a"的ASCII码,即数组索引0对应字母'a',索引1对应字母'b',以此类推。
具体步骤如下:
1. 创建一个大小为26的整型数组count,初始化每个元素为0。
2. 读取输入的字符串。
3. 使用一个循环遍历字符串的每个字符,直到遇到结束标志'.'。
4. 在循环中,首先判断当前字符是否为小写字母,如果是则进行下一步,否则跳过该字符。
5. 将当前字符转换为数组的索引,即将当前字符的ASCII码减去小写字母"a"的ASCII码。
6. 将count数组对应索引位置的元素加1。
7. 循环结束后,遍历count数组,每次输出字母和对应的出现次数,如果出现次数大于0。
8. 根据字母表的顺序输出字母和出现次数,中间用空格隔开。
下面是代码示例:
#include <iostream>
#include <string>
using namespace std;
int main() {
// 创建大小为26的数组count,存放字母出现次数
int count[26] = {0};
// 读取输入的字符串
string str;
cin >> str;
// 遍历字符串的每个字符,统计字母出现次数
for (int i = 0; i < str.length(); i++) {
char ch = str[i];
// 判断当前字符是否为小写字母
if (ch >= 'a' && ch <= 'z') {
// 将当前字符转换为数组索引
int index = ch - 'a';
// 统计字母出现次数
count[index]++;
}
}
// 输出字母和对应的出现次数
for (int i = 0; i < 26; i++) {
if (count[i] > 0) {
char ch = i + 'a';
cout << ch << ":" << count[i] << " ";
}
}
return 0;
}
这样,就可以实现统计C++字符串中字母出现的次数的功能。
如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^