题目分析,一共需要最多需要36个位置的数组,我们把前十个数组位置给0-9个数字字符存放空间,10-36的数组空间给到A-Z的存放
int main()
{
printf("请输入一串字符串内容,并且以#结束输入\n");
char arr[36], ch;//26个大写字符+10个数字字符
int i;
//初始化都为0
for (i = 0; i < 36; i++)
{
arr[i] = 0;
}
while ((ch = getchar()) != '#')
{
if (ch >= '0' && ch <= '9')
{
i = ch - '0';//0 ASCII 48
arr[i]++;
}
else if (ch >= 'A' && ch <= 'Z')
{
i = ch - 'A' + 10;//前十个数组位置放0-9出现的频率,后26个空间放字母的出现频率
arr[i]++;
}
}
FILE* inpf = fopen("s.txt", "w");
if (inpf == NULL)
{
perror("error");
exit(1);
}
for (i = 0; i < 10; i++)
{
fprintf(inpf, "%d 数字字符 出现的频率为: %d\n", i, arr[i]);
}
for (i = 10; i < 36; i++)
{
fprintf(inpf, "%c 字母字符 出现的频率为: %d\n", i + 55, arr[i]);
}
fclose(inpf)
return 0;
}