C语言:统计英文字符串的字符分布,即统计该字符串中每个字符的数量,只统计英文字母,不区分大小写,忽略其他非字母字符。输出按照 “字符:数量” 显示,每行一个结果,字符按字母表升序排列。
时间: 2024-03-20 22:40:22 浏览: 25
好的,以下是一个简单的 C 语言程序,可以实现该功能:
```c
#include <stdio.h>
#include <ctype.h>
#include <string.h>
int main() {
int count[26] = {0}; // 数组用于统计每个字母出现的次数
char str[100]; // 存储输入的字符串
int len, i, index;
printf("请输入一个英文字符串:\n");
fgets(str, sizeof(str), stdin);
len = strlen(str);
for (i = 0; i < len; i++) {
if (isalpha(str[i])) { // 判断是否为字母
index = tolower(str[i]) - 'a'; // 转换为小写字母后计算下标
count[index]++;
}
}
printf("字符分布如下:\n");
for (i = 0; i < 26; i++) {
if (count[i] > 0) {
printf("%c:%d\n", 'a' + i, count[i]);
}
}
return 0;
}
```
程序的思路是:先定义一个长度为 26 的整型数组 count,用于存储每个字母出现的次数。然后通过 fgets 函数获取用户输入的字符串,遍历字符串中的每个字符,判断是否为字母,如果是,则将其转换为小写字母,并计算出对应的数组下标,将对应元素加 1。最后遍历数组,输出结果。
注意:本程序只能处理字符串长度不超过 99 个字符的情况,如果需要处理更长的字符串,需要修改数组和输入函数的参数。