百练2745:显示器

2745:显示器

总时间限制: 
1000ms 
内存限制: 
65536kB
描述
你的一个朋友买了一台电脑。他以前只用过计算器,因为电脑的显示器上显示的数字的样子和计算器是不一样,所以当他使用电脑的时候会比较郁闷。为了帮助他,你决定写一个程序把在电脑上的数字显示得像计算器上一样。
输入
输入包括若干行,每行表示一个要显示的数。每行有两个整数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)由一个或者多个数字组成。
******************************************************
乍一看感觉这道题好难。。。这是因为陷入了一个误区,像这种排版题,最终输出的时候都是 按行输出的,而不是 一次性输出完一个数字!所以,关键搞清楚每一行都输出什么。把一个数字分成七段码来表示这个思路不错,按照每个数字在 每个段上覆盖的是什么字符,把它们存成数组。然后按照每行每列的规则输出就行了。注意每个数字都是占s+2列的,而且最后要多输出一个空行才行.....
#include <cstdio>
#include <cstring>
using namespace std;
char n1[11]="- -- -----";
char n2[11]="|   ||| ||";
char n3[11]="|||||  |||";
char n4[11]="  ----- --";
char n5[11]="| |   | | ";
char n6[11]="|| |||||||";
char n7[11]="- -- -- --";
int main()
{
    int s;
    char n[10];
    while(scanf("%d%s",&s,n)!=EOF){
        if(s==0&&n[0]=='0')  break;
        else{
            int len=strlen(n);
            int i,j,k;

            for(i=0;i<len;i++){
                printf(" ");
                for(j=0;j<s;j++){
                    printf("%c",n1[n[i]-'0']);
                }
                printf(" ");
                if(i!=len-1)
                    printf(" ");
            }
            printf("\n");

            for(i=2;i<=s+1;i++){
                for(j=0;j<len;j++){
                    printf("%c",n2[n[j]-'0']);
                    for(k=0;k<s;k++){
                        printf(" ");
                    }
                    if(j!=len-1)
                        printf("%c ",n3[n[j]-'0']);
                    else
                        printf("%c",n3[n[j]-'0']);
                }
                printf("\n");
            }

            for(i=0;i<len;i++){
                printf(" ");
                for(j=0;j<s;j++){
                    printf("%c",n4[n[i]-'0']);
                }
                printf(" ");
                if(i!=len-1)
                    printf(" ");
            }
            printf("\n");

            for(i=2;i<=s+1;i++){
                for(j=0;j<len;j++){
                    printf("%c",n5[n[j]-'0']);
                    for(k=0;k<s;k++){
                        printf(" ");
                    }
                    if(j!=len-1)
                        printf("%c ",n6[n[j]-'0']);
                    else
                        printf("%c",n6[n[j]-'0']);
                }
                printf("\n");
            }

            for(i=0;i<len;i++){
                printf(" ");
                for(j=0;j<s;j++){
                    printf("%c",n7[n[i]-'0']);
                }
                printf(" ");
                if(i!=len-1)
                    printf(" ");
            }
            printf("\n");
            printf("\n");
        }
    }
    return 0;
}
********************************
坚持,而不是打鸡血~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值