纯模拟即可。
运用gets读入一整行字符,并记录其中每个字母出现的个数。读入完毕后记录下最多的字母出现的个数。然后从那个数开始循环,内层对每一个字母进行判断,如果比它小就输出空格,否则输出星号+空格。最后一行输出字母+空格即可
#include<cstdio>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
using namespace std;
char a[110];
int num[27];
int main()
{
int n,len,mmax=-100;
for(int i=0;i<4;i++)
{
gets(a);
len=strlen(a);
for(int j=0;j<len;j++)
{
if(a[j]>='A'&&a[j]<='Z')
{
num[a[j]-'A']++;
}
}
}
for(int i=0;i<26;i++)
{
mmax=max(mmax,num[i]);
}
for(int i=mmax;i>0;i--)
{
for(int j=0;j<26;j++)
{
if(num[j]<i)
{
cout<<' '<<' ';
continue;
}
else if(num[j]>=i)
{
cout<<'*'<<' ';
continue;
}
}
cout<<endl;
}
for(int i=0;i<26;i++)
{
printf("%c ",i+'A');
}
return 0;
}