/*给一个字符串,请找出出现次数最多的大写英文字母
输入
第一行是一个整数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;
}