zzulioj 2664: A + B问题

4 篇文章 0 订阅

题目描述

众所周知1 + 1 = 2,321 + 10 = 331。

作为一名优秀的程序员,显然这个问题过于简单,因此我们将这一问题升级。

首先以*和.的形式给出一个A + B式,求这个式子的结果。

每个字符占五行五列,数字和数字、数字和符号两两之间以两个..间隔。

如下给出所有字符的表示形式:0123456789+

*****......*..*****..*****..*...*..*****..*****..*****..*****..*****....*.... 

*...*......*......*......*..*...*..*......*..........*..*...*..*...*....*.... 

*...*......*..*****..*****..*****..*****..*****....*....*****..*****..*****.. 

*...*......*..*..........*......*......*..*...*....*....*...*......*....*.... 

*****......*..*****..*****......*..*****..*****....*....*****..*****....*....  

输入

输入共五行,表示一个A + B式子,保证输入合法。(0 <= A, B <= 1010)

输出

输出一个整数,表示A + B的和。

样例输入

*****..*****......*....*........*..*****
....*......*......*....*........*..*...*
*****..*****......*..*****......*..*...*
....*..*..........*....*........*..*...*
*****..*****......*....*........*..*****

样例输出

331

提示

输入数字可能具有前导零。

c代码 

#include<stdio.h>
#include<string.h>
int main()
{
 int i,j,x;
 char a[10][10000],str[10000];
 int b[10000],xy;
 for(i=0;i<5;i++)
 {
  scanf("%s",str);
  x=strlen(str);
  int xx=0,xz=0;
  for(j=0;j<x;j++)
  {
   a[i][j]=str[j];
  }
 }
 int count=0,m=0,xn=0;
 for(j=0;j<x;j++)
 {
  xn++;
  if(xn==6)
  {
   xn=0;
   j=j+1;
   count=0;
   continue;
  }
  for(i=0;i<5;i++)
  {
   if(a[i][j]=='*')
    count++;
  }

  if(xn==5)
  {
   if(count==16)
   {
    b[m]=0;
    m++;
   }
   if(count==5)
   {
    b[m]=1;
    m++;
   }if(count==11)
   {
    b[m]=4;
    m++;
   }if(count==19)
   {
    b[m]=8;
    m++;
   }if(count==18&&a[3][j-4]=='*')
   {
    b[m]=6;
    m++;
   }else if(count==18)
   {
    b[m]=9;
    m++;
   }if(count==9&&a[1][j]=='*')
   {
    b[m]=7;
    m++;
   }else if(count==9)
   {
    b[m]=10;
    m++;
   }if(count==17&&a[1][j]=='*'&&a[3][j-4]=='*')
   {
    b[m]=2;
    m++;
   }else if(count==17&&a[1][j]=='*'&&a[3][j]=='*')
   {
    b[m]=3;
    m++;
   }else if(count==17)
   {
    b[m]=5;
    m++;
   }
  }
 }
 long long int sum1=0,sum=0;
 int s=0;
 for(i=0;i<m;i++)
 {
  if(b[i]==10)
  {
   i++;
   sum=sum1;
   sum1=0;
  }
  sum1=sum1*10+b[i];
 }
 printf("%lld\n",sum+sum1);
}

解释一下:

*****......*..*****..*****..*...*..*****..*****..*****..*****..*****....*.... 
*...*......*......*......*..*...*..*......*..........*..*...*..*...*....*.... 
*...*......*..*****..*****..*****..*****..*****....*....*****..*****..*****.. 
*...*......*..*..........*......*......*..*...*....*....*...*......*....*.... 
*****......*..*****..*****......*..*****..*****....*....*****..*****....*....  

分别是:

0 1 2 3 4 5 6 7 8 9 +

然后根据每个数字用几个 * 表示来分一下类

之后再从每个类中区分一下

例如2和5  *  一样多但位置不一样就判断一下就可以

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值