这一天qls在学校综合楼等电梯的时候看到了电梯数字的样子,突然觉得这样写数字特别有趣,于是自己想用程序跑出来。由于正常大小输出数字太小了,qls决定加大难度,他想画出不同大小的数字,你能帮他解决这个问题吗?
输入格式:
第一行输入一个数字n表示数字的大小(具体大小解释见样例解释)。(3≤n≤10)
第二行输入一串只含数字的字符串。(字符串长度不超过20)
输出格式:
输出字符串的图像,每两个数字图像之间有一个空格(具体解释见样例解释)。
样例1
样例输入
3
123
样例输出
* *** ***
* * *
* *** ***
* * *
* *** ***
样例2
样例输入
4
567
样例输出
**** **** ****
* * *
* * *
**** **** *
* * * *
* * * *
**** **** *
提示
数字按照电梯样式并用字符‘*’表示边,大小的定义是在一个n×(2n−1)的长方形表示数字,每两个数字之间用空格间隔。
例如大小为3的0到9样式如下:
#include<bits/stdc++.h>
using namespace std;
char s[10][20][10];
int main(){
int n;
cin>>n;
string str;
cin>>str;
int m;
m=2*n-1;
memset(s,' ',sizeof s);
for(int k=0;k<10;k++){
for(int i=0;i<m;i++){
for(int j=0;j<n;j++){
int x=m/2;
if(k==0){
if(i==0||i==m-1||j==0||j==n-1) s[k][i][j]='*';
}else if(k==1){
if(j==n-1) s[k][i][j]='*';
}else if(k==2){
if(i==0||i==x||i==m-1||(i<=x&&j==n-1)||(i>=x&&j==0)) s[k][i][j]='*';
}else if(k==3){
if(i==0||i==x||i==m-1||j==n-1) s[k][i][j]='*';
}else if(k==4){
if(j==n-1||i==x||(j==0&&i<=x)) s[k][i][j]='*';
}else if(k==5){
if((i<=x&&j==0)||(i>=x&&j==n-1)||i==0||i==x||i==m-1) s[k][i][j]='*';
}else if(k==6){
if(j==0||(i>=x&&j==n-1)||i==0||i==x||i==m-1) s[k][i][j]='*';
}else if(k==7){
if(i==0||j==n-1) s[k][i][j]='*';
}else if(k==8){
if(i==0||i==x||i==m-1||j==0||j==n-1) s[k][i][j]='*';
}else if(k==9){
if(j==n-1||i==0||i==x||i==m-1||(j==0&&i<=x)) s[k][i][j]='*';
}
}
}
}
for(int i=0;i<m;i++){
int f=0;
for(int k=0;k<str.size();k++){
if(f==1) cout<<' ';
int x;
x=str[k]-'0';
for(int j=0;j<n;j++){
cout<<s[x][i][j];
}
f=1;
}
cout<<endl;
}
return 0;
}