洛谷刷题C++语言 | P1598 垂直柱状图

学习C++从娃娃抓起!记录下洛谷C++学习和备考过程中的题目,记录每一个瞬间。

附上汇总贴:洛谷刷题C++语言 | 汇总_热爱编程的通信人的博客-CSDN博客


【题目描述】

写一个程序从输入文件中去读取四行大写字母(全都是大写的,每行不超过 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 <bits/stdc++.h>
using namespace std;

int main()
{
    int a[300]={0}, max=0;
    string s;
    for (int i=1; i<=4; i++) {
        getline(cin ,s);
        for (int j=0; j<s.length(); j++) {
            a[s[j]]++;
        }
    }
    for (int i='A'; i<='Z'; i++) {
        if (a[i]>max) max = a[i];
    }
    for (int i=max; i>0; i--) {
        for (int j='A'; j<'Z'; j++) {
            if (a[j]>=i) cout << "* ";
            else cout << "  ";
        }
        if (a['Z']>=i) cout << "*";
        else cout << " ";
        cout << endl;
    }
    for (char i='A'; i< 'Z'; i++) {
        cout << i << " ";
    }
    cout << 'Z';
    return 0;
}

【运行结果】

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

猜你喜欢

转载自blog.csdn.net/guolianggsta/article/details/132774717