显示器---输入输出

你的一个朋友买了一台电脑。他以前只用过计算器,因为电脑的显示器上显示的数字的样子和计算器是不一样,所以当他使用电脑的时候会比较郁闷。为了帮助他,你决定写一个程序把在电脑上的数字显示得像计算器上一样。

Input

输入包括若干行,每行表示一个要显示的数。每行有两个整数s和n (1 <= s <= 10, 0 <= n <= 99999999),这里n是要显示的数,s是要显示的数的尺寸。 

如果某行输入包括两个0,表示输入结束。这行不需要处理。

Output

显示的方式是:用s个'-'表示一个水平线段,用s个'|'表示一个垂直线段。这种情况下,每一个数字需要占用s+2列和2s+3行。另外,在两个数字之间要输出一个空白的列。在输出完每一个数之后,输出一个空白的行。注意:输出中空白的地方都要用空格来填充。

Sample Input

2 12345
3 67890
0 0

Sample Output

      --   --        -- 
   |    |    | |  | | 
   |    |    | |  | | 
      --   --   --   -- 
   | |       |    |    |
   | |       |    |    |
      --   --        -- 

 ---   ---   ---   ---   --- 
|         | |   | |   | |   |
|         | |   | |   | |   |
|         | |   | |   | |   |
 ---         ---   --- 
|   |     | |   |     | |   |
|   |     | |   |     | |   |
|   |     | |   |     | |   |
 ---         ---   ---   ---

Hint

数字(digit)指的是0,或者1,或者2……或者9。 
数(number)由一个或者多个数字组成。 

题解:将最多需要火柴的数,也就是0的七根火柴分别标上号码1,2,3,4,5,6,7;创建7个字符型数组(0,1,2...9)分别是什么字符( - 还是 | 还是 空格),输出即可。不过本题需要注意输出格式,防止PE。

扫描二维码关注公众号,回复: 5492653 查看本文章
​
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<iostream>
#include<algorithm>
#include<stack>
#define LL long long

using namespace std;
const int max_n=1e3+5;
int s,len,vis;
char n[100];
			//{"0123456789"}
char n1[100]={"- -- -----"};
char n2[100]={"|   ||| ||"};
char n3[100]={"|||||  |||"};
char n4[100]={"  ----- --"};
char n5[100]={"| |   | | "};
char n6[100]={"|| |||||||"};
char n7[100]={"- -- -- --"};
int main() 
{
	//freopen("1.in","r",stdin);
	//freopen("1.out","w",stdout);
	while(scanf("%d",&s)==1&&s)
	{
		scanf("%s",n);
		len=strlen(n);
		//1
		for(int i=0;i<len;i++)
		{
			vis=n[i]-'0';
			printf(" ");
			for(int i=0;i<s;i++)
			{
				printf("%c",n1[vis]);
			}
			printf("  ");
		}
		printf("\n");
		//2&3
		for(int j=0;j<s;j++)
		{
			for(int i=0;i<len;i++)
			{
				vis=n[i]-'0';
				printf("%c",n2[vis]);
				for(int k=0;k<s;k++)printf(" ");
				printf("%c",n3[vis]);
				printf(" ");
			}
			printf("\n");
		}
		//printf("\n");
		//4
		for(int i=0;i<len;i++)
		{
			vis=n[i]-'0';
			printf(" ");
			for(int i=0;i<s;i++)
			{
				printf("%c",n4[vis]);
			}
			printf("  ");
		}
		printf("\n");
		//5&6
		for(int j=0;j<s;j++)
		{
			for(int i=0;i<len;i++)
			{
				vis=n[i]-'0';
				printf("%c",n5[vis]);
				for(int k=0;k<s;k++)printf(" ");
				printf("%c",n6[vis]);
				printf(" ");
			}
			printf("\n");
		}
		//printf("\n");
		//7
		for(int i=0;i<len;i++)
		{
			vis=n[i]-'0';
			printf(" ");
			for(int i=0;i<s;i++)
			{
				printf("%c",n7[vis]);
			}
			printf("  ");
		}
		printf("\n\n");
		
	}
	return 0;
}

​

猜你喜欢

转载自blog.csdn.net/qq_43484493/article/details/87391431