题目分析,一共需要最多需要36个位置的数组,我们把前十个数组位置给0-9个数字字符存放空间,10-36的数组空间给到A-Z的存放
int main()
{printf("请输入一串字符串内容,并且以#结束输入\n");char arr[36], ch;//26个大写字符+10个数字字符int i;//初始化都为0for (i = 0; i < 36; i++){arr[i] = 0;}while ((ch = getchar()) != '#'){if (ch >= '0' && ch <= '9'){i = ch - '0';//0 ASCII 48arr[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;
}