显示器问题(是个水题)


总时间限制: 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


样例输出



思路很简单:

 

 1. 把每个数字看成由七个数码管组成的。如图:

 2. 用数组将每个数码管的状态存起来
 3. 用足够大的字符数组来存储每个数字的显示,注意存储时行列有变化
 4. 输出


 上代码

 

#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<string>
#include<string.h>

using namespace std;

int x,y;//记录行列
int smg[10][8]={{0,1,1,1,0,1,1,1},{0,0,0,1,0,0,1,0},{0,1,0,1,1,1,0,1},
                  {0,1,0,1,1,0,1,1},{0,0,1,1,1,0,1,0},{0,1,1,0,1,0,1,1},
                  {0,1,1,0,1,1,1,1},{0,1,0,1,0,0,1,0},{0,1,1,1,1,1,1,1},{0,1,1,1,1,0,1,1}};//数码管状态数组
char jieg[25][200];//记录每个数字的数组
void print(int m1,int n1,int n,int s)
{
    int x=m1;int y=n1;
    if(smg[n][1]==1)//第一个数码管
    {
        jieg[x][y]=' ';   
        for(int i=1;i<=s;i++)
        {
            jieg[x][y+i]='-';   
        }
        jieg[x][y+s+1]=' ';    
        x=m1;y=n1;
    }
    if(smg[n][4]==1)//第四个数码管
    {
        x=m1+s+1;
        jieg[x][y]=' ';       
        for(int i=1;i<=s;i++)
        {
            jieg[x][y+i]='-';   
        }
        jieg[x][y+s+1]=' ';   
        x=m1;y=n1;
    }
    if(smg[n][7]==1)//第七个数码管
    {
        x=m1+s+1+s+1;
        jieg[x][y]=' ';          
        for(int i=1;i<=s;i++)
        {
            jieg[x][y+i]='-';    
        }
        jieg[x][y+s+1]=' ';      
        x=m1;y=n1;
    }
    if(smg[n][2]==1)//第二个
    {
        x=m1+1;
        for(int i=0;i<s;i++)
        {
            jieg[x+i][y]='|';    
        }
        x=m1;y=n1;
    }
    if(smg[n][3]==1)//第三个
    {
        x=m1+1;y=n1+(s+1);
        for(int i=0;i<s;i++)
        {
            jieg[x+i][y]='|';   
        }
        x=m1;y=n1;
    }
    if(smg[n][5]==1)//第五个
    {
        x=m1+s+2;
        for(int i=0;i<s;i++)
        {
            jieg[x+i][y]='|';  
        }
        x=m1;y=n1;
    }
    if(smg[n][6]==1)//第六个
    {
        x=m1+s+2;y=n1+(s+1);
        for(int i=0;i<s;i++)
        {
            jieg[x+i][y]='|';     
        }
        x=m1;y=n1;
    }
}
int flag=0;//标志是否需要输出空格,保证最后不会有多余空格
int main()
{
    int s;string n;
    int nn[10]={0};
    int t;
    while(cin>>s>>n)
    {
        x=0;y=0;
        if(s==0&&n=="0")
            break;
        if(flag!=0)
            cout<<endl;
        for(int i=0;i<25;i++)//清空数组
        {
            for(int j=0;j<200;j++)
            {
                jieg[i][j]=' ';
            }
        }
        for(int i=0;i<n.length();i++)
        {
            int t=n[i]-'0';
            print(x,y,t,s);
            y=y+s+3;
        }
        int g=n.length()*(s+2)+n.length()-1;
        int h=2*s+3;
        for(int i=0;i<h;i++)
        {
            for(int j=0;j<g;j++)
            {
                cout<<jieg[i][j];
            }
            cout<<endl;
        }
        flag++;
    }
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值