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;
}