HDU-1228,A + B(字符串处理)

简介: HDU-1228,A + B(字符串处理)

Problem Description:


读入两个小于100的正整数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


解题思路:


这道题我们可以利用样例中的“+”和“=”来作为分隔符,用scanf去读入,因为这样就可以被中间的空格给中断,然后用strcmp进行比较就可以了,比较成功的将其转换成数字进行计算即可。具体的我们看代码


程序代码:


#include<stdio.h>
#include<string.h>
#include<stdlib.h>
char a[10][6]={"zero","one","two","three","four","five","six","seven","eight","nine"};
int ans(char ch[])
{
  for(int i=0;i<10;i++)
    if(strcmp(ch,a[i])==0)
      return i;
}
int main()
{
  char b[50],c[50];
  while(1)
  {
    int x=0,y=0;
    while(scanf("%s",b)&&strcmp(b,"+")!=0)
      x=x*10+ans(b);
    while(scanf("%s",c)&&strcmp(c,"=")!=0)
      y=y*10+ans(c);
    if(x==0&&y==0)
      return 0;
    else
      printf("%d\n",x+y);
  }
  return 0;
}
相关文章
|
8月前
|
测试技术
简单计算器 ——HDU(1237)
简单计算器 ——HDU(1237)
|
8月前
|
测试技术 C语言
hdu 1106排序 c语言解题
hdu 1106排序 c语言解题
46 0
|
测试技术 C语言
hdu 1106排序 c语言解题
hdu 1106排序 c语言解题
49 0
|
存储 C语言 C++
C++/C/PTA 字符串排序--string类的使用
先输入你要输入的字符串的个数。然后换行输入该组字符串。每个字符串以回车结束,每个字符串不多于一百个字符。
306 0
HDU-1048,The Hardest Problem Ever(字符串处理)
HDU-1048,The Hardest Problem Ever(字符串处理)
|
机器学习/深度学习
CodeForces 445A-DZY Loves Chessboard(字符串处理)
CodeForces 445A-DZY Loves Chessboard(字符串处理)
HDU-1062,Text Reverse(字符串处理 and 栈)
HDU-1062,Text Reverse(字符串处理 and 栈)
|
安全
HDU-1039,Easier Done Than Said?(字符串处理)
HDU-1039,Easier Done Than Said?(字符串处理)

热门文章

最新文章