C语言编程题目 给一个字符串,请找出出现次数最多的大写英文字母。

输入第一行是一个整数N,表示样例的个数。以后的每行一个字符串,串长不超过2000,且只含大写英文字母。输出每个样例输出一行,先是出现次数最多的大写英文字母,然后是它的出现... 输入
第一行是一个整数N,表示样例的个数。
以后的每行一个字符串,串长不超过2000,且只含大写英文字母。
输出
每个样例输出一行,先是出现次数最多的大写英文字母,然后是它的出现次数。如果存在多个大写英文字母符合题意,只要输出最小的那个。

Sample Input

2
ABCDEFGHIJKLMNOPQRSTUVWXYZ
AAAAABBBB

Sample Output

A 1
A 5
展开
 我来答
问明6E
高粉答主

2019-06-19 · 每个回答都超有意思的
知道答主
回答量:279
采纳率:100%
帮助的人:12.8万
展开全部

#include<stdio.h>

#include<string.h>

void main()

chara[100];

intfre[26];

int i,len,big=0;

gets(a);

for(i=0;i<26;i++)

fre[i]=0;

len=strlen(a);

for(i=0;i<len;i++)

if(a[i]>='a'&&a[i]<='z')

fre[a[i]-'a']++;

for(i=0;i<len;i++)

if(a[i]>='A'&&a[i]<='Z')

fre[a[i]-'A']++;

for(i=0;i<26;i++)

if(fre[i]>big)big=fre[i];

for(i=0;i<26;i++)

if(big==fre[i])

printf("%c\n",i+'a');

break;

扩展资料:

printf函数使用注意事项

1、域宽

%d:按整型数据的实际长度输出。

如果想输出指定宽度可以指定域宽,%md-->m域宽,打印出来以后,在控制台上,显示m位;

如果我们要打印的数的位数如果超过我们设定m则原样输出;

如果我们要打印的数的位数如果小于我们设定的位数,则补空白,具体如下:

如果m为正数,则左对齐(左侧补空白);

如果m为负数,则右对齐(右侧补空白)。

2、转义字符

如果想输出字符"%",则应该在“格式控制”字符串中用连续两个%表示。

如:printf("%f%%",1.0/3);输出结果:0.333333%。

一块月饼
2015-01-02 · TA获得超过318个赞
知道小有建树答主
回答量:155
采纳率:0%
帮助的人:66.2万
展开全部
//这个和楼上的思路是一样的,不过这是完整实现的
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
struct MaxGet//设置一个结构体存最大字符和出现次数
{
char maxchar;
int maxtime;
};
void main()
{
int Count[26]={0},n,i,j,temp=0;//Count数组表示A-Z出现次数计数
MaxGet maxgets[20];//程序最多能计算20条字符串,这个可以自己更改
char string[2000];//存字符串的字符数组
printf("输入样例个数:");
scanf("%d",&n);
for(i=0;i<n;i++)
{
printf("输入字符串:");
scanf("%s",string);
j=0;
while(string[j])//开始计数,65是A的ASCII码,这里等价于string[j]-'A'
{
Count[(int)(string[j]-65)]++;
j++;
}
for(j=0;j<26;j++)//找出出现最多的且是在前面的字符
{
if(Count[temp]<Count[j])
temp=j;
}
maxgets[i].maxchar=(char)(temp+65);//将结果存入存放结果的结构体数组中
maxgets[i].maxtime=Count[temp];
temp=0;//重置临时变量和Count数组,以便下一次处理
memset(Count,0,sizeof(Count));
}
for(i=0;i<n;i++)//输出结果
{
printf("%c  %d\n",maxgets[i].maxchar,maxgets[i].maxtime);
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友834a0a1e3
2015-01-02 · TA获得超过835个赞
知道小有建树答主
回答量:1031
采纳率:62%
帮助的人:162万
展开全部
思路如下
先定义一个数组s[26],下标0-25 分别对应A-Z
遍历整个字符串,统计每个字符出现的次数
char ch ;
char s[25];
memset(s,0,sizeof(s));//清空s数组
do 
{
    char ch = getchar();
    s[ch-'A']++;  //减去A的ASCII码之后恰好为0,对应数组下标
}
while(ch!='\0');

遍历一次找到s数组中的最大值,就是出现的最大次数 设为m

int count = 0;
int min_index = 0;
for(i=0;i<25;++i)
{
    if(count < s[i])  
    {
        count = s[i];
        min_index = i; //同样次数的最小字母对应下标
     }
}
char min_char = min_index + 'A';
putchar(min_char);为答案
自己组织一下编程实现吧,很简单的
希望对你有帮助!
追问
恩,谢谢,我自己想想。有问题再问你,请指教。
追答
请记得采纳哦~~~~
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2015-01-02
展开全部
void main(){
int index, i, max, n;
char ch, a[27];
scanf("%d", &n);
while (n--){
fflush(stdin);
memset(a, 0, 27);
while ((ch = getchar()) != '\n')
{
a[ch - 65]++;
}
max = 0; index = 0;
for (i = 0; i < 26; i++)
{
if (max < a[i]) { max = a[i]; index = i; }

}
printf("%c %d\n", index + 65, max);
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式