忘尘游
2021-09-06 22:56
采纳率: 88.9%
浏览 229

统计一串字符中出现次数最多的字符

【问题描述】
统计字符串里面哪个英文字母字符最多,并统计次数。
【输入形式】
第一行输入字符串。
【输出形式】
输出出现次数最多(相同则一起输出)的字符和次数,并用空格隔开。
【样例输入1】
asddfssaasswef
【样例输出1】
s 5
【样例输入2】
tomtomas
【样例输出2】
t 2
o 2
m 2
要求:要用到字符对应的ASCll码、数组
(希望给个完整的程序,有注释容易看懂,谢谢!)

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 邀请回答

5条回答 默认 最新

  • qfl_sdu 2021-09-06 23:11
    最佳回答

    代码如下:

    
    #include <stdio.h>
    int main()
    {
        int cnt[26] = {0};
        int zm[26];
        
        char buf[1000]={0};
        int i,j,tmp;
        scanf("%s",buf);
        for(i=0;buf[i]!='\0';i++)
        {
            cnt[buf[i]-'a']++;
        }
        for(i=0;i<26;i++)
            zm[i] = i;
        //排序
        for (i=0;i<25;i++)
        {
            for(j=0;j<25-i;j++)
            {
                if(cnt[j] < cnt[j+1])
                {
                    tmp = cnt[j];
                    cnt[j] = cnt[j+1];
                    cnt[j+1] = tmp;
    
                    tmp = zm[j];
                    zm[j] = zm[j+1];
                    zm[j+1] = tmp;
                }
            }
        }
        //显示
        printf("%c %d\n",zm[0]+'a',cnt[0]);
        for(i=1;i<26;i++)
        {
            if(cnt[i] == cnt[0])
                printf("%c %d\n",zm[i]+'a',cnt[0]);
            else
                break;
        }
        return 0;
    }
    
    评论
    解决 1 无用
    打赏 举报
查看更多回答(4条)

相关推荐 更多相似问题