题目描述
写一个程序从输入文件中去读取四行大写字母(全都是大写的,每行不超过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<iostream>
#include<cstdio>
#include<cstring>
#include<string.h>
using namespace std;
char page[500];
int word[30];
int n;
int main()
{
int k = 4;
while(k--)
{
gets(page);
int n = 0;
for(int i = 0; i < strlen(page); i++)
{
if(page[i]>=65&&page[i]<=90)
{
word[page[i]-65]++;
}
}
}
for(int i = 0; i < 26; i++)
{
if(word[i]>n)
n = word[i];
}
for(int i = 0; i < n; i++)
{
for(int j = 0; j < 26; j++)
{
if(word[j]<n&&j!=25)
{
printf(" ");
word[j]++;
}
else if(word[j]<n&&j==25)
{
printf(" ");
word[j]++;
}
else if(j == 25)
printf("*");
else
printf("* ");
}
printf("\n");
}
for(int i = 0; i < 25; i++)
{
printf("%c ",65+i);
}
printf("Z");
}