A. 学姐的数码管 2014新生暑假个人排位赛03
时间限制 1000 ms
内存限制 65536 KB
题目描述
学姐的七段数码管玩的出神入化。 现在给你一个浮点数,你需要把它以七段数码管的形式输出出来。 一个 (2∗n+1)∗n 的矩阵来表示七段数码管,若下标均从0开始,则以第0列的两个,第 n−1 列的两个,第0行的一个,第 n 行的一个,第 2∗n 行的一个表示七个段。小数点所占矩形为 (2∗n+1)∗1 ,点在中间最下面一列。每一个数字或小数点矩阵用一列空格隔开。 数码管亮的部分用#覆盖,其余部分用空格补全,若一个数字或小数点的行末尾无#,也要用空格字符补全为 (2∗n+1)∗n 细节参见样例。
输入格式
输入有多组数据,数据不超过100组,每组数据给一个整数 n(3≤n≤10) ,和一个浮点数,输入保证每一个浮点数的总长度为4位且没有前导0。
输出格式
输出他的数码管显示。每组数据末尾输出一个空行。
输入样例
3 2330
3 1456
4 78.9
输出样例
### ### ### ###
# # # # #
# # # # #
### ### ### # #
# # # # #
# # # # #
### ### ### ###
# # # ### ###
# # # # #
# # # # #
# ### ### ###
# # # # #
# # # # #
# # ### ###
#### #### ####
# # # # #
# # # # #
# # # # #
# #### ####
# # # #
# # # #
# # # #
# #### # ####
代码:
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<ctype.h>
//#define LOCAL
using namespace std;
int n;
char str[10];
int main()
{
#ifdef LOCAL
freopen("input.txt","r",stdin);
#endif
while(scanf("%d%s",&n,str+1)==2)
{
int len=strlen(str+1);
for(int i=1;i<=2*n+1;i++)
{
for(int j=1;j<=len;j++)
{
if(isdigit(str[j]))
{
for(int k=1;k<=n;k++)
{
if(str[j]=='1')
{
if(k==n)printf("#");
else printf(" ");
}
if(str[j]=='2')
{
if(i==1||i==n+1||i==2*n+1)printf("#");
if(i>1&&i<n+1){if(k==n)printf("#");else printf(" ");}
if(i>n+1&&i<2*n+1){if(k==1)printf("#");else printf(" ");}
}
if(str[j]=='3')
{
if(i==1||i==n+1||i==2*n+1)printf("#");
else {if(k==n)printf("#");else printf(" ");}
}
if(str[j]=='4')
{
if(i==n+1)printf("#");
if(i>=1&&i<=n)
{
if(k==1||k==n)printf("#");
else printf(" ");
}
if(i>n+1)
{
if(k==n)printf("#");
else printf(" ");
}
}
if(str[j]=='5')
{
if(i==1||i==n+1||i==2*n+1)printf("#");
if(i>1&&i<n+1){if(k==1)printf("#");else printf(" ");}
if(i>n+1&&i<2*n+1){if(k==n)printf("#");else printf(" ");}
}
if(str[j]=='6')
{
if(i==1||i==n+1||i==2*n+1)printf("#");
if(i>1&&i<n+1){if(k==1)printf("#");else printf(" ");}
if(i>n+1&&i<2*n+1){if(k==n||k==1)printf("#");else printf(" ");}
}
if(str[j]=='7')
{
if(i==1)printf("#");
else {if(k==n)printf("#");else printf(" ");}
}
if(str[j]=='8')
{
if(i==1||i==n+1||i==2*n+1)printf("#");
else{if(k==n||k==1)printf("#");else printf(" ");}
}
if(str[j]=='9')
{
if(i==1||i==n+1||i==2*n+1)printf("#");
if(i>1&&i<n+1){if(k==1||k==n)printf("#");else printf(" ");}
if(i>n+1&&i<2*n+1){if(k==n)printf("#");else printf(" ");}
}
if(str[j]=='0')
{
if(i==1||i==2*n+1)printf("#");
else{if(k==n||k==1)printf("#");else printf(" ");}
}
}
}
else
{
if(i==2*n+1)printf("#");
else printf(" ");
}
if(j!=len)printf(" ");
}
printf("\n");
}
printf("\n");
}
return 0;
}