这一天qls在学校综合楼等电梯的时候看到了电梯数字的样子,突然觉得这样写数字特别有趣,于是自己想用程序跑出来。由于正常大小输出数字太小了,qls决定加大难度,他想画出不同大小的数字,你能帮他解决这个问题吗?
输入格式:
第一行输入一个数字n表示数字的大小(具体大小解释见样例解释)。(3≤n≤10)
第二行输入一串只含数字的字符串。(字符串长度不超过20)
输出格式:
输出字符串的图像,每两个数字图像之间有一个空格(具体解释见样例解释)。.
提示
数字按照电梯样式并用字符‘*’表示边,大小的定义是在一个n×(2n−1)的长方形表示数字,每两个数字之间用空格间隔。
例如大小为3的0到9样式如下:
思路:我们将每个数字的字符拆成交点和线,那么当n扩大时,只有线会被放大n倍,交点不变。

显而易见的,对于红色的交点,保持原样输出,对于绿色的线,输出(n-2)次。这样就能通过n=3的图输出[3,10]的放大图.
#include<bits/stdc++.h>
#define int long long
#define _ 0
using namespace std;
int n;
string s;
const int N = 1e6+5;
string num[15][6] = {// 存 0-9 的图
{"***","* *","* *","* *","***"},
{" *"," *"," *"," *"," *"},
{"***"," *","***","* ","***"},
{"***"," *","***"," *","***"},
{"* *","* *","***"," *"," *"},
{"***","* ","***"," *","***"},
{"***","* ","***","* *","***"},
{"***"," *"," *"," *"," *"},
{"***","* *","***","* *","***"},
{"***","* *","***"," *","***"},
};
void outputline(int i){// 输出行
for(int j=0;j<s.size();j++){
for(int k= 0;k<num[s[j]-'0'][i].size();k++){
if(k==1) {//k==1时,当前像素为线
int cnt = n - 2;
while (cnt)cout << num[s[j] - '0'][i][k],cnt--;
}else{
cout<<num[s[j]-'0'][i][k];
}
}
cout<<" \n"[j==s.size()-1];
}
}
signed main(){
cin>>n;
cin>>s;
for(int i=0;i<5;i++){
if(i==1 || i==3){//当行==1/3时,当前为线
int ha = n-2;
while(ha){
outputline(i);
ha--;
}
}else{
outputline(i);
}
}
return ~~(0^_^0);
}