总时间限制: 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
样例输出

思路很简单:
1. 把每个数字看成由七个数码管组成的。如图:
2. 用数组将每个数码管的状态存起来
3. 用足够大的字符数组来存储每个数字的显示,注意存储时行列有变化
4. 输出
上代码
#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<string>
#include<string.h>
using namespace std;
int x,y;//记录行列
int smg[10][8]={{0,1,1,1,0,1,1,1},{0,0,0,1,0,0,1,0},{0,1,0,1,1,1,0,1},
{0,1,0,1,1,0,1,1},{0,0,1,1,1,0,1,0},{0,1,1,0,1,0,1,1},
{0,1,1,0,1,1,1,1},{0,1,0,1,0,0,1,0},{0,1,1,1,1,1,1,1},{0,1,1,1,1,0,1,1}};//数码管状态数组
char jieg[25][200];//记录每个数字的数组
void print(int m1,int n1,int n,int s)
{
int x=m1;int y=n1;
if(smg[n][1]==1)//第一个数码管
{
jieg[x][y]=' ';
for(int i=1;i<=s;i++)
{
jieg[x][y+i]='-';
}
jieg[x][y+s+1]=' ';
x=m1;y=n1;
}
if(smg[n][4]==1)//第四个数码管
{
x=m1+s+1;
jieg[x][y]=' ';
for(int i=1;i<=s;i++)
{
jieg[x][y+i]='-';
}
jieg[x][y+s+1]=' ';
x=m1;y=n1;
}
if(smg[n][7]==1)//第七个数码管
{
x=m1+s+1+s+1;
jieg[x][y]=' ';
for(int i=1;i<=s;i++)
{
jieg[x][y+i]='-';
}
jieg[x][y+s+1]=' ';
x=m1;y=n1;
}
if(smg[n][2]==1)//第二个
{
x=m1+1;
for(int i=0;i<s;i++)
{
jieg[x+i][y]='|';
}
x=m1;y=n1;
}
if(smg[n][3]==1)//第三个
{
x=m1+1;y=n1+(s+1);
for(int i=0;i<s;i++)
{
jieg[x+i][y]='|';
}
x=m1;y=n1;
}
if(smg[n][5]==1)//第五个
{
x=m1+s+2;
for(int i=0;i<s;i++)
{
jieg[x+i][y]='|';
}
x=m1;y=n1;
}
if(smg[n][6]==1)//第六个
{
x=m1+s+2;y=n1+(s+1);
for(int i=0;i<s;i++)
{
jieg[x+i][y]='|';
}
x=m1;y=n1;
}
}
int flag=0;//标志是否需要输出空格,保证最后不会有多余空格
int main()
{
int s;string n;
int nn[10]={0};
int t;
while(cin>>s>>n)
{
x=0;y=0;
if(s==0&&n=="0")
break;
if(flag!=0)
cout<<endl;
for(int i=0;i<25;i++)//清空数组
{
for(int j=0;j<200;j++)
{
jieg[i][j]=' ';
}
}
for(int i=0;i<n.length();i++)
{
int t=n[i]-'0';
print(x,y,t,s);
y=y+s+3;
}
int g=n.length()*(s+2)+n.length()-1;
int h=2*s+3;
for(int i=0;i<h;i++)
{
for(int j=0;j<g;j++)
{
cout<<jieg[i][j];
}
cout<<endl;
}
flag++;
}
return 0;
}