7-271 统计字符个数
分数 10
作者 usx程序设计类课程组
单位 绍兴文理学院
输入若干的字符串,每个字符串中只包含数字字符和大小写英文字母,统计字符串中有出现的不同字符的出现次数。
输入格式:
测试数据有多组,处理到文件尾。每组测试输入一个字符串(不超过80个字符)。
输出格式:
对于每组测试,按字符串中有出现的字符的ASCII码升序逐行输出不同的字符及其个数(两个数据之间留一个空格),每两组测试数据之间留一空行,输出格式参照输出样例。
输入样例:
12123
A1c1B
输出样例:
1 2
2 2
3 1
1 2
A 1
B 1
c 1
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#define MAX_N 100
#define MAX_L 80
char str[MAX_N][MAX_L];
int cnt[MAX_N][256];
int n;
int main() {
while (fgets(str[n], MAX_L, stdin)) { //输入到文件末尾
int len = strlen(str[n]);
if (str[n][len - 1] == '\n') str[n][--len] = '\0'; //把末尾的'\n'换成'\0'
for (int i = 0; i < len; i++)
if (isalnum(str[n][i])) cnt[n][(int)str[n][i]]++;
//判断一个字符是否是字母或者(十进制)数字 并对字符数字对应的下标自增
n++;
}
for (int i = 0; i < n; i++) { //遍历输出多组数据
for (int j = 0; j < 256; j++)
if (cnt[i][j] > 0) //证明存在该字符
printf("%c %d\n", j, cnt[i][j]);
if (i < n - 1) puts(""); //每组数据空一行
}
return 0;
}