这个题目怎么写呀,要求用c语言,希望有代码分析,麻烦亲们了

/*给一个字符串,请找出出现次数最多的大写英文字母
输入
第一行是一个整数N,表示样例的个数。
以后的每行一个字符串,串长不超过2000,且只含大写英文字母
输出
每个样例输出一行,先是出现次数最多的大写英文字母,然后是它的出现次数。如果存在多个大写英文字母符合题意,只要输出最小的那个。
Sample Input
2
ABCDEFGHIJKLMNOPQRSTUVWXYZ
AAAAABBBB
Sample Output
A 1
A 5*/

你先定义一个大小为91的数组 A[91]={0} 数组每一个元素等于0,然后for循环 从0开始 一个一个的检测你的字符串组 如果字符串的ASCLL在 'A'到'Z'之间的话
你就把对应的A[srt[i]]++;就行了这样你的A数组从A['A']开始一直到A['Z']储存的就是对应大写字母出现的次数 后面你就对这个数组进行操作,对里面非0的
元素进行比较 如果都相等的话你就输出第一个非0的字符和在数组中的值 有最大的就输出最大的

#include
#include
int main()
{
int i,a,max;
int sd[26];
char c,str[2010];
while(scanf("%d",&a)!=EOF)
{
scanf("%s",&str);
max=0;
memset(sd,0,26);
for(c='A',i=0;i {
sd[str[i]-65]++;
if(sd[str[i]-65]>max)
{
c=str[i];
max=sd[str[i]-65];
}
}
printf("%c %d\n",c,max);
}
return 0;
}

#include
#include

http://blog.csdn.net/hzj96421/article/details/44964143?locationNum=8

 #include<stdio.h>  
#include<string.h>  
int main()  
{  
    char a[100];  
    int b[26];  
    int n,i=0,p,max=0;  
    scanf("%d",&n);  
    scanf("%s",a);  
    for(i=0;i<26;i++)  
        b[i]=0;  
    for(i=0;i<n;i++)  
        b[a[i]-'a']++;  
    for(i=0;i<26;i++)  
    {  
        if (max<b[i])  
        {  
            max=b[i];  
            p=i;  
        }  
    }  
    printf("%c\n",p+'a');  
    return 0;  
}