编写一个程序接收4行大写字母组成的字符串(每行字符串中字符的个数不能超过80),打印每个字母(不考虑空格、标点符号、分隔符和数字)在这4行字符串文本输入中出现的字数,并按照要求的输出格式显示结果。
【输入】
共4行,每行输入的都是大写字母构成的字符串,并且每行长度不超过80
【输出】
1行或者多行;使用*号表示字母出现的次数,其中每个大写字母之间用空格进行分割。要求每一行的结尾不要输出不必要的空格,在空行部分不要输入其他的符号(比如,等)。
【样例输入】
THE QUICKBROWN FOX JUMPED OVER THE LAZY DOG.
THIS ISAN EXAMPLE TO TEST FOR YOUR
HISTOGRAMPROGRAM
HELLO!
【样例输出】
![](https://img-my.csdn.net/uploads/201211/29/1354165844_5646.jpg)
可以采用二维数组也可以采用一维,博客上已经有大神采用了二维数组写完了。我采用的是一维,并且写起来很麻烦.
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
int main()
{
int i,j;
char str[100] ,str1[100],str2[100],str3[100];
gets(str);
gets(str1);
gets(str2);
gets(str3);
strcat(str,str1);strcat(str,str2);strcat(str,str3);//合并输入的字符串成一个串
//printf(str);
int ch[26];
for(i=0;i<26;i++) ch[i]=0;
for(i=0;i<strlen(str);i++)
{
switch(str[i])
{
case 'A':ch[0]++;break;
case 'B':ch[1]++;break;
case 'C':ch[2]++;break;
case 'D':ch[3]++;break;
case 'E':ch[4]++;break;
case 'F':ch[5]++;break;
case 'G':ch[6]++;break;
case 'H':ch[7]++;break;
case 'I':ch[8]++;break;
case 'J':ch[9]++;break;
case 'K':ch[10]++;break;
case 'L':ch[11]++;break;
case 'M':ch[12]++;break;
case 'N':ch[13]++;break;
case 'O':ch[14]++;break;
case 'P':ch[15]++;break;
case 'Q':ch[16]++;break;
case 'R':ch[17]++;break;
case 'S':ch[18]++;break;
case 'T':ch[19]++;break;
case 'U':ch[20]++;break;
case 'V':ch[21]++;break;
case 'W':ch[22]++;break;
case 'X':ch[23]++;break;
case 'Y':ch[24]++;break;
case 'Z':ch[25]++;break;
}
}
int res=0;
for(i=0;i<26;i++)
{
if(res<ch[i])
res=ch[i];
}
printf("%d\n",res);
for(i=res;i>0;i--)
{
for(j=0;j<26;j++)
{
if(j<25){
if(res>ch[j]) printf(" ");
else printf("* ");
}
if(j==25)
{
if(res>ch[j]) printf(" \n");
else printf("*\n");
}
}
res--;
}
printf("A B C D E F G H I J K L M N O P Q R S T U V W X Y Z\n");
return 0;
}