解题思路:
注意事项:
定义了一个void Count(char [],int)函数用于统计各字符串中各个英文字母的个数,并找出最大值输出
参考代码:
#include<string.h> #include<stdio.h> void Count(char string[], int n) { int count[26] = { 0 };//记录26个英文字母分别出现的次数 int i, j; for (i = 0; i < n; i++)//判断每个字符 { for (j = 97; j < 123; j++)//判断每个字符是哪个英文字母,97是a,122是z { if (string[i] == j) { count[j - 97]++;//记录个数 break; } } } int k; int temp; int max = 0;//max初始化为0 for (k = 25; k >= 0; k--)//从z往a遍历,保证出现相同个数的字母时,输出的是ascii最小的 { if (count[k] >= max) { max = count[k];//记录出现的个数的最大值 temp = k;//temp储存最终要输出的字符及个数 } } printf("%c %d\n", (temp + 97), count[temp]);//%c输出(temp+97)即a~z,count[temp]即出现的次数 } int main() { int n; scanf("%d", &n); getchar(); char str[100][1000];//二维字符数组,输入多个不等长字符串 int i; for (i = 0; i < n; i++) { gets(str[i]); } for (i = 0; i < n; i++)//对每个字符串进行统计和结果输出 { Count(str[i], strlen(str[i])); } return 0; }
0.0分
0 人评分