垂直柱状图
题目描述
写一个程序从输入文件中去读取四行大写字母(全都是大写的,每行不超过 $100$ 个字符),然后用柱状图输出每个字符在输入文件中出现的次数。严格地按照输出样例来安排你的输出格式。
输入格式
四行字符,由大写字母组成,每行不超过 $100$ 个字符
输出格式
由若干行组成,前几行由空格和星号组成,最后一行则是由空格和字母组成的。在任何一行末尾不要打印不需要的多余空格。不要打印任何空行。
样例 #1
样例输入 #1
THE QUICK BROWN FOX JUMPED OVER THE LAZY DOG.
THIS IS AN EXAMPLE TO TEST FOR YOUR
HISTOGRAM PROGRAM.
HELLO!
样例输出 #1
*
*
* *
* * * *
* * * *
* * * * * *
* * * * * * * * * *
* * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * * *
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<bits/stdc++.h>
using namespace std;
string s;
int num[26],maxa=0;
int main()
{
for(int i=1;i<=4;i++)
{
getline(cin,s);
int len=s.length();
for(int j=0;j<len;j++)
{
if(s[j]>='A'&&s[j]<='Z') num[s[j]-'A']++;
}
}
for(int i=0;i<26;i++)
{
maxa=max(maxa,num[i]);
}
for(int i=maxa;i>0;i--)
{
for(int j=0;j<26;j++)
{
if(num[j]>=i&&j<25) cout<<"* ";
else if(num[j]>=i&&j==25) cout<<"*";
else if(num[j]<i&&j<25) cout<<" ";
else cout<<" ";
}
cout<<"\n";
}
for(char i='A';i<='Z';i++)
{
printf("%c ",i);
}
return 0;
}