Problem A
Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other)
Total Submission(s) : 31 Accepted Submission(s) : 15
Font: Times New Roman | Verdana | Georgia
Font Size: ← →
Problem Description
读入两个小于100的正整数A和B,计算A+B.
需要注意的是:A和B的每一位数字由对应的英文单词给出.
需要注意的是:A和B的每一位数字由对应的英文单词给出.
Input
测试输入包含若干测试用例,每个测试用例占一行,格式为"A + B =",相邻两字符串有一个空格间隔.当A和B同时为0时输入结束,相应的结果不要输出.
Output
对每个测试用例输出1行,即A+B的值.
Sample Input
one + two = three four + five six = zero seven + eight nine = zero + zero =
Sample Output
3 90 96
A+B,思路大家都还是会有的吧!
反正我也是胡搞乱搞的。
这题的思路就不说了。
#include <stdio.h>
#include <string.h>
#include <math.h>
#include <stdlib.h>
#include <iostream>
#include <algorithm>
#include <queue>
using namespace std;
char num[10][100]={"zero","one","two","three","four","five","six","seven","eight","nine"};
char a[10][100],b[10][100];
char A[10],B[10];
int Aans,Bans;
int main()
{
//freopen("in.txt","r",stdin);
// freopen("out.txt","w",stdout);
int i,j,len,aN,bN,flag,k;
char str[1000];
while(gets(str)!=NULL)
{
if(strcmp(str,"zero + zero =")==0)
break;
memset(A,'\0',sizeof(A));
memset(B,'\0',sizeof(B));
len=strlen(str);
aN=bN=j=0;
flag=0;
for(i=0;i<len;i++)
{
if(str[i]==' ' && str[i-1]>='a' && str[i-1]<='z')
{
j=0;
if(!flag)
aN++;
else
bN++;
continue;
}
if(str[i]==' ')
continue;
if(str[i]=='+')
{
flag=1;
continue;
}
if(str[i]=='=')
continue;
if(!flag)
{
a[aN][j]=str[i];
j++;
}
else
{
b[bN][j]=str[i];
j++;
}
}
for(i=0;i<aN;i++)
{
//printf("<%s> ",a[i]);
for(k=0;k<=10;k++)
if(strcmp(a[i],num[k])==0)
{
A[i]=k+'0';
break;
}
}
// printf("Aans=%s\n",A);
sscanf(A,"%d",&Aans);
// printf("Aans=%d\n",Aans);
// printf("*********\n");
for(i=0;i<bN;i++)
{
//printf("<<%s>> ",b[i]);
for(k=0;k<=10;k++)
if(strcmp(b[i],num[k])==0)
{
B[i]=k+'0';
break;
}
}
sscanf(B,"%d",&Bans);
// printf("Bans=%d\n",Bans);
//printf("*********\n");
printf("%d\n",Aans+Bans);
memset(a,'\0',sizeof(a));
memset(b,'\0',sizeof(b));
}
return 0;
}