题目描述
写一个程序从输入文件中去读取四行大写字母(全都是大写的,每行不超过100个字符),然后用柱状图输出每个字符在输入文件中出现的次数。严格地按照输出样例来安排你的输出格式。
输入格式
四行字符,由大写字母组成,每行不超过100个字符
输出格式
由若干行组成,前几行由空格和星号组成,最后一行则是由空格和字母组成的。在任何一行末尾不要打印不需要的多余空格。不要打印任何空行。
样例
输入#1
THE QUICK BROWN FOX JUMPED OVER THE LAZY DOG.
THIS IS AN EXAMPLE TO TEST FOR YOUR
HISTOGRAM PROGRAM.
HELLO!
Copy
输出#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
Copy
数据范围
每行输出后面不允许出现多余的空格。
视频讲解:垂直柱状图_哔哩哔哩_bilibili
思路:每次找到剩余的最大值,输出星号
看代码吧,我描述的不清楚
我写的不高级
//*** 吴** ***//
#include<bits/stdc++.h>
using namespace std;
int s[27]={0};
int main()
{
string a;
int max=INT_MIN;
for(int i=1;i<=4;i++)
{
getline(cin,a);
for(int j=0;j<a.size();j++)
{
if(a[j]>='A'&&a[j]<='Z')
{
s[a[j]-64]++;
}
}
}
for(int i=1;i<=26;i++)
{
if(s[i]>max)
{
max=s[i];
}
}
for(int i=max;i>=1;i--)
{
for(int j=1;j<=26;j++)
{
if(s[j]>=i)
{
cout<<"* ";
}else
{
cout<<" ";
}
}
cout<<endl;
}
for(int i=1;i<=26;i++)
{
cout<<char(i+64)<<" ";
}
}
大佬写的:
#include<iostream>
#include<climits>
#include<string>
#include<windows.h>
using namespace std;
string s;
int b[30];
bool check() {
for(int i = 1; i <= 26; ++i)
if(b[i] != 0) return false;
return true;
} int main() {
ios::sync_with_stdio(false);
cin.tie(0),cout.tie(0);
for(int i = 1; i <= 4; ++i) {
getline(cin, s);
for(int j = 0; j < s.size(); ++j)
if(s[j] >= 'A' && s[j] <= 'Z') b[s[j] - 64] ++;
} while(1) {
if(check()) {
cout << "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";
return 0;
} int Max = INT_MIN;
for(int i = 1; i <= 26; ++i)
if(b[i] > Max) Max = b[i];
for(int i = 1; i <= 26; ++i) {
if(b[i] == Max) {
if(i == 1) cout << "*";
else cout << " *";
b[i] --;
} else {
if(i == 1) cout << " ";
else cout << " ";
}
} cout << "\n";
} return 0;
}
我写的YOU:
#include<bits/stdc++.h>
using namespace std;
void picture()
{
int cnt[127]={0};
int max=0;
string test;
for(int i=0;i<4;i++)
{
getline(cin,test);
for(int i=0;i<test.size();i++)
{
if(test[i]>='A' && test[i]<='Z')
{
cnt[test[i]]++;
if(cnt[test[i]]>max) max=cnt[test[i]];
}
}
}
for(int i='A';i<='Z';i++) cnt[i]=max-cnt[i];
for(int i=0;i<max;i++)
{
for(int j='A';j<='Z';j++)
{
if(cnt[j]>0) cout<<" ";
else cout<<"*";
if(j!='Z') cout<<" ";
cnt[j]--;
}
cout<<"\n";
}
cout<<"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";
}
int main()
{
picture();
return 0;
}
播放量一位数~~~~~~
我
求求了~~