题目描述
众所周知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 * 一样多但位置不一样就判断一下就可以