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;
}
相关文章
|
10月前
|
自然语言处理 算法
KMP算法(A + B for you again—HDU - 1867 )
KMP算法(A + B for you again—HDU - 1867 )
|
10月前
|
测试技术 C语言
hdu 1106排序 c语言解题
hdu 1106排序 c语言解题
50 0
|
10月前
|
存储 C语言
【PTA刷题】请编写函数,求子串(详解+代码)
【PTA刷题】请编写函数,求子串(详解+代码)
140 0
|
测试技术 C语言
hdu 1106排序 c语言解题
hdu 1106排序 c语言解题
55 0
【代码随想录】LC 150. 逆波兰表达式求值
目录 一、题目 1、原题链接 2、题目描述 二、解题报告 1、思路分析 2、时间复杂度 3、代码详解 三、知识风暴 字符串转数字,数字转字符串
86 0
LeetCode contest 185 1417. 重新格式化字符串
LeetCode contest 185 1417. 重新格式化字符串
|
机器学习/深度学习
CodeForces 445A-DZY Loves Chessboard(字符串处理)
CodeForces 445A-DZY Loves Chessboard(字符串处理)
HDU-1048,The Hardest Problem Ever(字符串处理)
HDU-1048,The Hardest Problem Ever(字符串处理)