加载中...

浙江理工大学入队200题——18I

问题 I: LC-显示器2297

题目描述

你的一个朋友刚买了一台新电脑。 到目前为止,他曾经使用过的最强大的计算机是袖珍计算器。 现在,看着他的新电脑,他有点失望,因为他非常喜欢他的计算器的LC显示器。 所以你决定编写一个程序,在他的计算机上以类似LC显示的方式显示数字。

输入

输入包含多行,每行显示一个。 每行包含两个整数s,n(1 <= s <= 10,0 <= n <= 99 999 999),其中n是要显示的数字,s是应显示的大小。 输入文件将由包含两个零的行终止。 不应处理此行。

输出

以LC显示样式输出输入文件中给出的数字,使用s“ - ”表示水平线段和s“|” 表示垂直线段。 每个数字正好占据s + 2列和2s + 3行。 (确保用空格填充数字占据的所有空白区域,也包括最后一个数字。)两个数之间必须有一列空白。 在每个数字后输出一个空行。 (您将在示例输出中找到每个数字的样本。)

样例输入 Copy

2 12345
3 67890
0 0

样例输出 Copy

     --   --        -- 
|      |    | |  | | 
|      |    | |  | | 
     --   --   --   -- 
|   |       |    |    |
|   |       |    |    |
     --   --        -- 

---   ---   ---   ---   --- 
|         | |   | |   | |   |
|         | |   | |   | |   |
|         | |   | |   | |   |
 ---         ---   --- 
|   |     | |   |     | |   |
|   |     | |   |     | |   |
|   |     | |   |     | |   |
 ---         ---   ---   ---

题解

头疼麻烦题
仔细观察,找规律
有头顶,底座,左上,左下,右上,右下的分别有
23567890;2345680;456890;2680;2347890;134567890;
由于我们不能直接输出1的形状后再输出2,所以打表写不出来,我们要考虑同一行的数,也就是同时考虑到n的每一个元素,因此我们把n例如12345拆到a[0]-a[4],根据每一个数子的特性来判断。
例如s=2时1 4算头的时候就是s+2

点击查看代码
for(i=1;i<=s+2;i++)
{
	printf(" ");
}
否则23567890算头就要--
点击查看代码
else
		{
			printf(" ");
				for(i=2;i<=s+1;i++)
				{
					printf("-");
				}
				printf(" ");
			}
			printf(" ");
例如上面的,其他自己看代码把,搬运自

https://blog.csdn.net/AbigailWilliams2/article/details/121617198

代码(AC)

点击查看代码
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
int main()
{
	int a[10];
	int n,i,s,j,t,k;
	while(scanf("%d%d",&s,&n)!=EOF)
	{
		if(s==0 && n==0) break;
		t=0;
		if(n==0)
		{
			t=1;
			a[t]=0;
		}
		else
		{
			while(n!=0)
			{
				t++;
				a[t]=n%10;
				n=n/10;
			}
		}
		for(j=t;j>=1;j--)
		{
			if(a[j]==1 || a[j]==4)
			{
				for(i=1;i<=s+2;i++)
				{
					printf(" ");
				}
			}
			else
			{
				printf(" ");
				for(i=2;i<=s+1;i++)
				{
					printf("-");
				}
				printf(" ");
			}
			printf(" ");
		}
		printf("\n");
		k=s;
		while(k--)
		{
			for(j=t;j>=1;j--)
			{
				if(a[j]==5 || a[j]==6)
				{
					printf("|");
					for(i=2;i<=s+2;i++)
					{
						printf(" ");
					}
				}
				else if(a[j]==1 || a[j]==2 || a[j]==3 || a[j]==7)
				{
					for(i=2;i<=s+2;i++)
					{
						printf(" ");
					}
					printf("|");
				}
				else
				{
					printf("|");
					for(i=2;i<=s+1;i++)
					{
						printf(" ");
					}
					printf("|");
				}
				printf(" ");
			}
			printf("\n");
		}
		for(j=t;j>=1;j--)
		{
			if(a[j]==1 || a[j]==7 || a[j]==0)
			{
				for(i=1;i<=s+2;i++)
				{
					printf(" ");
				}
			}
			else
			{
				printf(" ");
				for(i=2;i<=s+1;i++)
				{
					printf("-");
				}
				printf(" ");
			}
			printf(" ");
		}
		printf("\n");
		k=s;
		while(k--)
		{
			for(j=t;j>=1;j--)
			{
				if(a[j]==2)
				{
					printf("|");
					for(i=2;i<=s+2;i++)
					{
						printf(" ");
					}
				}
			
				else if(a[j]==1 || a[j]==4 || a[j]==3 || a[j]==7 || a[j]==5 || a[j]==9)
				{
					for(i=2;i<=s+2;i++)
					{
						printf(" ");
					}
					printf("|");
				}
				else
				{
					printf("|");
					for(i=2;i<=s+1;i++)
					{
						printf(" ");
					}
					printf("|");
				}
				printf(" ");
			}
			printf("\n");
		}
		for(j=t;j>=1;j--)
		{
			if(a[j]==1 || a[j]==4 || a[j]==7)
			{
				for(i=1;i<=s+2;i++)
				{
					printf(" ");
				}
			}
			else
			{
				printf(" ");
				for(i=2;i<=s+1;i++)
				{
					printf("-");
				}
				printf(" ");
			}
			printf(" ");
		}
		printf("\n");
		printf("\n");
	}
	return 0;
}
posted @ 2022-10-30 14:46  shany212  阅读(88)  评论(0编辑  收藏  举报