题目:https://www.luogu.org/problemnew/show/P1598
注.本文主要作为自己的学习笔记。
题目描述
写一个程序从输入文件中去读取四行大写字母(全都是大写的,每行不超过100个字符),然后用柱状图输出每个字符在输入文件中出现的次数。严格地按照输出样例来安排你的输出格式。
输入格式:
四行字符,由大写字母组成,每行不超过100个字符
输出格式:
由若干行组成,前几行由空格和星号组成,最后一行则是由空格和字母组成的。在任何一行末尾不要打印不需要的多余空格。不要打印任何空行。
输入样例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<stdio.h>
int main(){
int a,b,i,j,l=0;
int n[27]={0};
for(l=1;l<=4;){
a=getchar();
if(a=='\n') l++;
for(i=1;i<=26;i++)
if(a==i+64) {n[i]++;printf("%c ",a);break;}
}
printf("\n");
for(i=1;i<=26;i++)
{
printf("%d ",n[i]);
}
printf("\n");
b=n[1];
for(i=1;i<=26;i++)
if(b<n[i]) b=n[i];
for(i=1;i<=26;i++)
n[i]=b-n[i];
for(i=1;i<=b;i++){
for(j=1;j<=26;j++)
{
if(n[j]>=i) printf(" ");
else printf("* ");
} printf("\n");}
for(i=1;i<=26;i++)
printf("%c ",i+64);
printf("\n");
for(i=1;i<=26;i++)
{
printf("%d ",n[i]);
}
return 0;
}
/*
THE QUICK BROWN FOX JUMPED OVER THE LAZY DOG.
THIS IS AN EXAMPLE TO TEST FOR YOUR
HISTOGRAM PROGRAM.
HELLO!
*/
PS :本博客属于中国石油大学胜利学院ACM协会所有!
By:朱天宇