题目描述
写一个程序从输入文件中去读取四行大写字母(全都是大写的,每行不超过100个字符),然后用柱状图输出每个字符在输入文件中出现的次数。严格地按照输出样例来安排你的输出格式。
输入格式
四行字符,由大写字母组成,每行不超过100个字符
输出格式
由若干行组成,前几行由空格和星号组成,最后一行则是由空格和字母组成的。在任何一行末尾不要打印不需要的多余空格。不要打印任何空行。
输入输出样例
输入
THE QUICK BROWN FOX JUMPED OVER THE LAZY DOG.
THIS IS AN EXAMPLE TO TEST FOR YOUR
HISTOGRAM PROGRAM.
HELLO!
输出
*
*
* *
* * * *
* * * *
* * * * * *
* * * * * * * * * *
* * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * * *
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
说明/提示
每行输出后面不允许出现多余的空格。
代码(答案正确,只是超时了)
#include <stdio.h>
#include <string.h>
#define max(a,b) (a>b?a:b)
int main()
{
char s[100]={0};
int ret[26]={0};
for(int i=0;i<4;i++){
scanf("%[^\n]",s); //一旦遇到\n,就跳出缓冲区,不读取\n,所以要清空缓存区
//printf("%d",i);
int n = strlen(s);
while(getchar()!='\n');
for(int j=0;j<n;j++){
if(65<=s[j] && s[j]<=90){
ret[s[j]-65]++;
}
}
}
int max=ret[0]; //经过统计,各个字母的数量都存在 ret[26] 里面了,之后找到最大字母数量
for(int i=1;i<26;i++){
if(max<ret[i])max=ret[i];
}
for(int i=max;i>0;i--){ // 从上往下,依次加上 * 号
for(int j=0;j<26;j++){
if(i<=ret[j]){
printf("* ");
continue;
}
printf(" ");
}
printf("\n");
}
for(int i=0;i<26;i++){
printf("%c ",65+i);
}
}