OpenJudge_P1747 显示器
来源:互联网 发布:生命有一种绝对 知乎 编辑:程序博客网 时间:2024/04/30 09:12
总时间限制: 1000ms 内存限制: 65536kB
描述
你的一个朋友买了一台电脑。他以前只用过计算器,因为电脑的显示器上显示的数字的样子和计算器是不一样,所以当他使用电脑的时候会比较郁闷。为了帮助他,你决定写一个程序把在电脑上的数字显示得像计算器上一样。
输入
输入包括若干行,每行表示一个要显示的数。每行有两个整数s和n (1 <= s <= 10, 0 <= n <= 99999999),这里n是要显示的数,s是要显示的数的尺寸。
如果某行输入包括两个0,表示输入结束。这行不需要处理。
输出
显示的方式是:用s个’-‘表示一个水平线段,用s个’|’表示一个垂直线段。这种情况下,每一个数字需要占用s+2列和2s+3行。另外,在两个数字之间要输出一个空白的列。在输出完每一个数之后,输出一个空白的行。注意:输出中空白的地方都要用空格来填充。
样例输入
2 12345
3 67890
0 0
样例输出
提示
数字(digit)指的是0,或者1,或者2……或者9。
数(number)由一个或者多个数字组成。
打表题,打了半天表
200+代码 3000B+
最后因为多输出空格提交了好几次没过
友情提示Presentation Error 格式错误
wqn百度翻译给我来个提交错误
#include<cstdio>#include<cstring>#include<iostream>using namespace std;#define N 15int s,t;int num[N];char ans[N];int in(){ memset(num,0,sizeof(num)); char ch=getchar();t=0; while(ch<'0'||ch>'9') ch=getchar(); while(ch>='0'&&ch<='9'){ num[++t]=ch-'0'; ch=getchar(); } return 0;}void print(int m,int h){ if(h==1||h==s+2||h==2*s+3){ switch(m){ case 0: if(h==s+2){ for(int i=1;i<=s+2;i++) putchar(' '); break; } else{ putchar(' '); for(int i=2;i<s+2;i++) putchar('-'); putchar(' '); break; } case 1: for(int i=1;i<=s+2;i++) putchar(' '); break; case 2:case 3: putchar(' '); for(int i=2;i<s+2;i++) putchar('-'); putchar(' '); break; case 4: if(h==1||h==2*s+3){ for(int i=1;i<=s+2;i++) putchar(' '); break; } else{ putchar(' '); for(int i=2;i<s+2;i++) putchar('-'); putchar(' '); break; } case 5:case 6: putchar(' '); for(int i=2;i<s+2;i++) putchar('-'); putchar(' '); break; case 7: if(h==1){ putchar(' '); for(int i=2;i<s+2;i++) putchar('-'); putchar(' '); break; } else{ for(int i=1;i<=s+2;i++) putchar(' '); break; } case 8:case 9: putchar(' '); for(int i=2;i<s+2;i++) putchar('-'); putchar(' '); break; } } else{ switch(m){ case 0: putchar('|'); for(int i=2;i<s+2;i++) putchar(' '); putchar('|'); break; case 1:case 3: for(int i=1;i<s+2;i++) putchar(' '); putchar('|'); break; case 2: if(h<s+2){ for(int i=1;i<s+2;i++) putchar(' '); putchar('|'); break; } else{ putchar('|'); for(int i=1;i<s+2;i++) putchar(' '); break; } case 4: if(h<s+2){ putchar('|'); for(int i=2;i<s+2;i++) putchar(' '); putchar('|'); break; } else{ for(int i=1;i<s+2;i++) putchar(' '); putchar('|'); break; } case 5: if(h<s+2){ putchar('|'); for(int i=1;i<s+2;i++) putchar(' '); break; } else{ for(int i=1;i<s+2;i++) putchar(' '); putchar('|'); break; } case 6: if(h<s+2){ putchar('|'); for(int i=1;i<s+2;i++) putchar(' '); break; } else{ putchar('|'); for(int i=2;i<s+2;i++) putchar(' '); putchar('|'); break; } case 7: for(int i=1;i<s+2;i++) putchar(' '); putchar('|'); break; case 8: putchar('|'); for(int i=2;i<s+2;i++) putchar(' '); putchar('|'); break; case 9: if(h<s+2){ putchar('|'); for(int i=2;i<s+2;i++) putchar(' '); putchar('|'); break; } else{ for(int i=1;i<s+2;i++) putchar(' '); putchar('|'); break; } } }}int main(){ while(1){ scanf("%d",&s); if(!s) break; in(); for(int i=1;i<=2*s+3;i++){ for(int j=1;j<=t;j++){ print(num[j],i); putchar(' '); } printf("\n"); } printf("\n"); } return 0;}
1 0
- OpenJudge_P1747 显示器
- 显示器
- 显示器
- 显示器
- 显示器
- 显示器
- CRT显示器
- 倒计时显示器
- 显示器厂商
- 显示器设置
- 显示器调节
- LED显示器
- LCD显示器
- 显示器接口类型
- 显示器指令
- 双屏显示器
- 关闭显示器
- 显示器分类
- 关于js中匹配字符时遇到的问题
- 一共81个,开源大数据处理工具汇总(上)
- Leetcode174: Combination Sum III
- 读取联系人和添加联系人
- Java与模式 之 I/O库中的应用
- OpenJudge_P1747 显示器
- jvm加载class文件的原理机制
- Magento新用户注册,新订单生成 取消给客人发邮件
- log4j.properties配置详解
- Android中横竖屏切换
- zookeeper API
- iOS NSNotification的使用
- 查看服务器硬件信息
- [Built-in Functions] - Z