• 【洛谷 P5730】【深基5.例10】显示屏 题解(数组+循环)


    【深基5.例10】显示屏

    题目描述

    液晶屏上,每个阿拉伯数字都是可以显示成 3 × 5 3\times5 3×5 的点阵的(其中 X 表示亮点,. 表示暗点)。现在给出数字位数(不超过 100 100 100)和一串数字,要求输出这些数字在显示屏上的效果。数字的显示方式如同样例输出,注意每个数字之间都有一列间隔。

    输入格式

    第一行输入一个正整数 n n n,表示数字的位数。

    第二行输入一个长度为 n n n 的自然数。

    输出格式

    输出五行,表示显示屏上的数字。

    样例 #1

    样例输入 #1

    10
    0123456789
    
    • 1
    • 2

    样例输出 #1

    XXX...X.XXX.XXX.X.X.XXX.XXX.XXX.XXX.XXX
    X.X...X...X...X.X.X.X...X.....X.X.X.X.X
    X.X...X.XXX.XXX.XXX.XXX.XXX...X.XXX.XXX
    X.X...X.X.....X...X...X.X.X...X.X.X...X
    XXX...X.XXX.XXX...X.XXX.XXX...X.XXX.XXX
    
    • 1
    • 2
    • 3
    • 4
    • 5

    提示

    数据保证, 1 ≤ n ≤ 100 1 \leq n \leq 100 1n100


    思路

    使用一个二维数组 t 来存储数字 0 到 9 的显示模式。每个数字的显示模式由一个 5x3 的字符数组表示,其中 ‘X’ 表示亮点,‘.’ 表示空白。

    根据输入的数字字符串,使用 printNum 函数将每个数字的显示模式复制到一个二维字符数组 s 中。在复制过程中,使用 offset 变量来记录每个数字的偏移量,以便正确地放置数字。每个数字之间通过 printLine 函数插入一行空白。最后,将 s 数组中的内容输出到屏幕上。


    AC代码

    #include 
    #include 
    #define AUTHOR "HEX9CF"
    using namespace std;
    
    const int N = 1e3 + 5;
    const char t[10][5][3] = {{ 'X', 'X', 'X', 'X', '.', 'X', 'X', '.', 'X', 'X', '.', 'X', 'X', 'X', 'X', }, { '.', '.', 'X', '.', '.', 'X', '.', '.', 'X', '.', '.', 'X', '.', '.', 'X', }, { 'X', 'X', 'X', '.', '.', 'X', 'X', 'X', 'X', 'X', '.', '.', 'X', 'X', 'X', }, { 'X', 'X', 'X', '.', '.', 'X', 'X', 'X', 'X', '.', '.', 'X', 'X', 'X', 'X', }, { 'X', '.', 'X', 'X', '.', 'X', 'X', 'X', 'X', '.', '.', 'X', '.', '.', 'X', }, { 'X', 'X', 'X', 'X', '.', '.', 'X', 'X', 'X', '.', '.', 'X', 'X', 'X', 'X', }, { 'X', 'X', 'X', 'X', '.', '.', 'X', 'X', 'X', 'X', '.', 'X', 'X', 'X', 'X', }, { 'X', 'X', 'X', '.', '.', 'X', '.', '.', 'X', '.', '.', 'X', '.', '.', 'X', }, { 'X', 'X', 'X', 'X', '.', 'X', 'X', 'X', 'X', 'X', '.', 'X', 'X', 'X', 'X', }, { 'X', 'X', 'X', 'X', '.', 'X', 'X', 'X', 'X', '.', '.', 'X', 'X', 'X', 'X', }};
    
    int n;
    int offset;
    string str;
    char s[5][N];
    
    void printNum(int x)
    {
        for (int i = 0; i < 5; i++)
        {
            for (int j = 0; j < 3; j++)
            {
                s[i][offset + j] = t[x][i][j];
            }
        }
        offset += 3;
    }
    
    void printLine()
    {
        for (int i = 0; i < 5; i++)
        {
            s[i][offset] = '.';
        }
        offset++;
    }
    
    int main()
    {
        cin >> n;
        cin >> str;
        offset = 0;
        for (int i = 0; i < n; i++)
        {
            if (i)
            {
                printLine();
            }
            printNum(str[i] - '0');
        }
        // cout << offset << endl;
        for (int i = 0; i < 5; i++)
        {
            for (int j = 0; j <= offset; j++)
            {
                putchar(s[i][j]);
            }
            putchar('\n');
        }
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
  • 相关阅读:
    STM32人工智能检测-筛选机器人
    如何通过实例对象获取虚函数表,并调用对应的虚函数
    Java 大后端各种架构图汇总(建议收藏)
    代码随想录-015-剑指Offer206. 反转链表
    Bootstrap Table 实现 分页选中
    开源MyBatisGenerator组件源码分析
    codeforces每日5题(均1600)-第三十三天
    流媒体协议之RTSP详解
    pulsar集群搭建_亲测成功
    鸿蒙-实践课程六 android、HarmonyOS 权限对比
  • 原文地址:https://blog.csdn.net/qq_34988204/article/details/133654051