zoukankan      html  css  js  c++  java
  • [OpenJudge] 显示器(模拟)

    02:显示器

    描述
    你的一个朋友买了一台电脑。他以前只用过计算器,因为电脑的显示器上显示的数字的样子和计算器是不一样,所以当他使用电脑的时候会比较郁闷。为了帮助他,你决定写一个程序把在电脑上的数字显示得像计算器上一样。
    输入
    输入包括若干行,每行表示一个要显示的数。每行有两个整数s和n (1 <= s <= 10, 0 <= n <= 99999999),这里n是要显示的数,s是要显示的数的尺寸。

    如果某行输入包括两个0,表示输入结束。这行不需要处理。
    输出
    显示的方式是:用s个'-'表示一个水平线段,用s个'|'表示一个垂直线段。这种情况下,每一个数字需要占用s+2列和2s+3行。另外,在两个数字之间要输出一个空白的列。在输出完每一个数之后,输出一个空白的行。注意:输出中空白的地方都要用空格来填充。
    样例输入
    2 12345
    3 67890
    0 0
    
    样例输出
          --   --        -- 
       |    |    | |  | | 
       |    |    | |  | | 
          --   --   --   -- 
       | |       |    |    |
       | |       |    |    |
          --   --        -- 
    
     ---   ---   ---   ---   --- 
    |         | |   | |   | |   |
    |         | |   | |   | |   |
    |         | |   | |   | |   |
     ---         ---   --- 
    |   |     | |   |     | |   |
    |   |     | |   |     | |   |
    |   |     | |   |     | |   |
     ---         ---   ---   ---
    
    提示
    数字(digit)指的是0,或者1,或者2……或者9。
    数(number)由一个或者多个数字组成。
    题解
    刚开始看到这道题是懵逼的,只用过计算器,所以当他使用电脑的时候会比较郁闷?呵呵。。。 
    一开始打算把每个字的情况写出来,然后写完1之后突然发现打印一个数字之后就没法打印下个一数字了,于是放弃了这个方法。
    然后发现1,3,5行都是- , 2,4行都是|,选择一行一行的写。
    首先一个字占n+2列,每两个字之间空一格,每排字占2n+3行,其中1,n+2,2n+3情况相似,2~n+1 和 n+3~2n+2也是如此、
    1,3,5排都是  _---(s个)---_   两边各一个空格 ,或者没有 - 就是 s+2个空格。
    2,4排分为 “左","右","左右" 其余的为空格
    然后根据每个数字每部分的情况判断并分五种情况写出来就行了
    #include<iostream>
    using namespace std;
    int main()
    {
        int n;
        string s;
        while(cin >> n >> s){
            if(n==0 && s=="0") break;
            int l=s.length();
            for(int i=1;i<=2*n+3;i++){
                if(i==1){
                    for(int j=0;j<l;j++){
                        if(s[j]=='2'||s[j]=='3'||s[j]=='5'||s[j]=='6'||s[j]=='7'||s[j]=='8'||s[j]=='9'||s[j]=='0'){
                            cout << ' ';
                            for(int k=1;k<=n;k++){
                                cout << '-';
                            }
                            cout << ' ';
                        }
                        else {
                            for(int k=1;k<=n+2;k++){
                                cout << ' ';
                            }
                        }
                        cout << ' ';
                    }
                }
                
                if(i>=2&&i<=n+1){
                    for(int j=0;j<l;j++){
                        if(s[j]=='1'||s[j]=='2'||s[j]=='3'||s[j]=='7'){
                            for(int k=1;k<=n+1;k++){
                                cout << ' ';
                            }
                            cout << '|';
                        }
                        else if(s[j]=='5'||s[j]=='6'){
                            cout << '|';
                            for(int k=1;k<=n+1;k++){
                                cout << ' ';
                            }
                        }
                        else {
                            cout << '|';
                            for(int i=1;i<=n;i++){
                                cout << ' ';
                            }
                            cout << '|';
                        }
                        cout << ' ';
                    }
                }
                
                if(i==n+2){
                    for(int j=0;j<l;j++){
                        if(s[j]=='2'||s[j]=='3'||s[j]=='4'||s[j]=='5'||s[j]=='6'||s[j]=='8'||s[j]=='9'){
                            cout << ' ';
                            for(int k=1;k<=n;k++){
                                cout << '-';
                            }
                            cout << ' ';
                        }
                        else {
                            for(int k=1;k<=n+2;k++){
                                cout << ' ';
                            }
                        }
                        cout << ' ';
                    }
                }
                
                if(i>=n+3&&i<=2*n+2){
                    for(int j=0;j<l;j++){
                        if(s[j]=='1'||s[j]=='3'||s[j]=='4'||s[j]=='5'||s[j]=='7'||s[j]=='9'){
                            for(int k=1;k<=n+1;k++){
                                cout << ' ';
                            }
                            cout << '|';
                        }
                        else if(s[j]=='2'){
                            cout << '|';
                            for(int k=1;k<=n+1;k++){
                                cout << ' ';
                            }
                        }
                        else {
                            cout << '|';
                            for(int i=1;i<=n;i++){
                                cout << ' ';
                            }
                            cout << '|';
                        }
                        cout << ' ';
                    }
                }
                
                if(i==2*n+3){
                    for(int j=0;j<l;j++){
                        if(s[j]=='2'||s[j]=='3'||s[j]=='5'||s[j]=='6'||s[j]=='8'||s[j]=='9'||s[j]=='0'){
                            cout << ' ';
                            for(int k=1;k<=n;k++){
                                cout << '-';
                            }
                            cout << ' ';
                        }
                        else {
                            for(int k=1;k<=n+2;k++){
                                cout << ' ';
                            }
                        }
                        cout << ' ';
                    }
                }
                
                cout << endl;
            }
            cout << endl;
        }
        return 0;
    }
    View Code

    一个计算器上的数字显示单元,可以看作由以下编号从1 到7 的7 个笔画组成:

    那么,我们可以说,数字8 覆盖了所有的笔画,数字7 覆盖笔画1、3 和6,而数字1覆盖笔画3、6。注意,每个笔画都是由s 个’-‘或s 个’|’组成。

        输出时,先输出第1 行,即整数n 中所有数字里的笔画1,然后输出第2 行到第s+1 行,即所有数字的笔画2 和笔画3,接下来是第s+2 行,即所有数字的笔画4,再接下来是第s+3行到2×s+2 行,,就是所有数字的笔画 5 和笔画6,最后的第2×s+3 行,是所有数字的笔画7。如果某个数字d 没有覆盖某个笔画m (m = 1…7),那么,输出数字d 的笔画m 的时候,就应该都输出空格;如果覆盖了笔画m,则输出s 个’-‘或s 个’|’,这取决于笔画m 是横的还是竖的。

    由上思路,解决这道题目的关键,就在于如何记录每个数字都覆盖了哪些笔画。实际上,如果我们记录的是每个笔画都被哪些数字覆盖,则程序实现起来更为容易。一个笔画被哪些数字所覆盖,可以用一个数组来记录,比如记录笔画1 覆盖情况的数组如下:

    char n1[11] = {"- -- -----"};

    其中,n1[i](i = 0……9) 代表笔画1 是否被数字i 覆盖。如果是,则n1[i] 为'-',如果否,则n1[i]为空格。上面的数组的值体现了笔画1 被数字0, 2, 3, 5, 6, 7, 8, 9 覆盖。

    对于竖向的笔画2,由字符 '|' 组成,则记录其覆盖情况的数组如下:

    char n2[11] = {"|   ||| ||"};

    该数组的值体现了笔画2 被数字0, 4, 5, 6, 8, 9 覆盖。

    #include <stdio.h>
    #include <string.h>
    char n1[11]={"- -- -----"};//笔画1 被数字0,2,3,5,6,7,8,9 覆盖
    char n2[11]={"|   ||| ||"};//笔画2 被数字0,4,5,6,8,9 覆盖
    char n3[11]={"|||||  |||"};//笔画3 被数字0,1,2,3,4,7,8,9 覆盖
    char n4[11]={"  ----- --"};//笔画4 被数字2,3,4,5,6,8,9 覆盖
    char n5[11]={"| |   | | "};//笔画5 被数字0,2,6,8覆盖
    char n6[11]={"|| |||||||"};//笔画6 被数字0,1,3,4,5,6,7,8,9 覆盖
    char n7[11]={"- -- -- --"};//笔画7 被数字0,2,3,5,6,8,9 覆盖
    int main(void)
    {
        int s;
        char szNumber[20];
        int nDigit , nLength, i , j , k;
    while(1)
        {
            scanf( "%d%s", &s, szNumber);
            if (s == 0)
                break;
            nLength = strlen(szNumber);
            for (i = 0 ; i < nLength ; i++)
            {   //输出所有数字的笔画1
                nDigit = szNumber[i] - '0';
                printf(" ");
                for (j = 0 ; j < s ; j++) //一个笔画由s 个字符组成
                    printf("%c", n1[nDigit]);
                printf("  ");//两个空格
            }
            printf("
    ");
    for (i = 0 ; i < s ; i++)
            { //输出所有数字的笔画2 和笔画3
                for (j = 0 ; j < nLength ; j++)
                {
                    nDigit = szNumber[j] - '0';
                    printf("%c", n2[nDigit]);
                    for (k = 0 ; k < s ; k++)
                        printf(" "); //笔画2 和笔画3 之间的空格
                    printf("%c ", n3[nDigit]);//有一个空格
                }
                printf("
    ");
            }
            for (i = 0 ; i < nLength ; i++)
            {   //输出所有数字的笔画4
                printf(" ");
                nDigit = szNumber[i] - '0';
                for (j = 0 ; j < s ; j++)
                    printf("%c", n4[nDigit]);
                printf("  ");//两个空格
            }
            printf("
    ");
    for (i = 0 ; i < s ; i++)
            {   //输出所有数字的笔画5 和笔画6
                for (j = 0 ; j < nLength ; j++)
                {
                    nDigit = szNumber[j] - '0';
                    printf("%c", n5[nDigit]);
                    for (k = 0 ; k < s ; k++)    printf( " "); //笔画5 和笔画6 之间的空格
                    printf("%c ", n6[nDigit]);//有一个空格
                }
                printf("
    ");
            }
            for (i = 0 ; i < nLength ; i++)
            { //输出所有数字的笔画7
                printf(" ");
                nDigit = szNumber[i] - '0';
                for (j = 0 ; j < s ; j++)       printf("%c", n7[nDigit]);
                printf("  ");//两个空格
            }
            printf("
    ");      printf("
    ");
        }
        return 0;
    }
    View Code

    实现技巧

    一个笔画被哪些数字所覆盖,最直接的想法是用整型数组来记录,比如:

    int n1[10] = {1, 0, 1, 1, 0, 1, 1, 1, 1, 1 };

    表示笔画1 的被覆盖情况。可是与其在数字i 的笔画1 所处的位置进行输出的时候,根据n1[i]的值决定输出空格还是'-'’ ,还不如直接用下面的char 类型数组来表示覆盖情况:

    char n1[11] = {"- -- -----"};

    这样,在数字i 的笔画1 所处的位置进行输出的时候,只要输出s 个n1[i]就行了。这是一个很好的思路,它提醒我们,以后在编程时设置一些标志的时候,要考虑一下是否可以直接用更有意义的东西将0,1 这样的标志代替。

  • 相关阅读:
    java基础学习
    形参和返回值
    内部类
    常用API(String、StringBuilder)【1】
    什么是servlet
    servlet2.5和3.0的区别,servlet4.0注解
    什么是事务
    jdk环境配置(转载)
    idea中运行Tomcat后控制台出现乱码(统一设置成UTF-8)
    java数组
  • 原文地址:https://www.cnblogs.com/a867686201/p/6344247.html
Copyright © 2011-2022 走看看