其他分享
首页 > 其他分享> > P5730 显示屏题解

P5730 显示屏题解

作者:互联网

题目传递门

总结:

1、常量数组是解题的关键,把这10个数字转为数组就费了我不少劲。
2、先打印行,再打印列是亘古不变的真理。行数是固定的,就是5行,列是根据要打印啥就通过计算位移找到数字的开始列取得的,重复的列数也是固定的,难点就是计算位移了。

#include <bits/stdc++.h>

using namespace std;

string a[5] =
        {"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"
        };

int main() {
    int n;
    string s;
    cin >> n >> s;//由于我们是用C++的string读入的,并不是使用C的 char数组读入,所以,n没用上

    //每个数字打5行
    //0---0
    //1---4
    //2---8
    //3---12
    //i--->4*i
    for (int i = 0; i <= 4; i++) { //一共5行,从0到4
        //每个数字
        for (int j = 0; j < s.size(); j++) {
            //每个数字都是固定的列数.只不过位移不同
            //要打印啥数字?
            int c = s[j] - '0';
            //每一行打3列
            for (int k = 0; k < 3; k++)
                //c这个数字的,第i行,第j列,需要找出位置关系描述
                printf("%c", a[i][4 * c + k]);//4:场宽,c:数字,4*c就是找到对应数字的开始位置,就是上面的找规律
            //再打一列.
            if (j < s.size() - 1) printf(".");
        }
        printf("\n");
    }
    return 0;
}

标签:...,P5730,string,int,题解,XXX,显示屏,---,数组
来源: https://www.cnblogs.com/littlehb/p/15039130.html