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;
}
相关文章
|
6月前
|
C语言
c语言编程练习题:7-2 I Love GPLT
这道超级简单的题目没有任何输入。 你只需要把这句很重要的话 —— I Love GPLT ——竖着输出就可以了。 所谓“竖着输出”,是指每个字符占一行(包括空格),即每行只能有1个字符和回车。 代码长度限制16 KB时间限制400 ms内存限制64 MB
70 0
|
6月前
|
测试技术
简单计算器 ——HDU(1237)
简单计算器 ——HDU(1237)
|
6月前
|
测试技术 C语言
hdu 1106排序 c语言解题
hdu 1106排序 c语言解题
39 0
|
6月前
|
Java
每日一题《剑指offer》字符串篇之替换空格
每日一题《剑指offer》字符串篇之替换空格
57 0
每日一题《剑指offer》字符串篇之替换空格
|
6月前
|
存储 C语言
【PTA刷题】请编写函数,求子串(详解+代码)
【PTA刷题】请编写函数,求子串(详解+代码)
120 0
|
6月前
|
存储 C语言
【PTA刷题】 求子串(代码+详解)
【PTA刷题】 求子串(代码+详解)
141 0
|
测试技术 C语言
hdu 1106排序 c语言解题
hdu 1106排序 c语言解题
41 0
|
开发者 Python
Python OJ题经典字符串操作——大小写转换
本文介绍了如何使用Python中的 str.swapcase() 方法对字符串进行大小写转换,并提供了一道相关的题目及解题过程。
176 0
华为机试每日一练--第九题: 字符串反转
华为机试每日一练--第九题: 字符串反转
华为机试每日一练--第九题: 字符串反转
|
存储 Java Python
【Python】力扣刷题之有效的括号,利用字符串替换解题,用栈解决
有效的括号,利用字符串替换解题,用栈解决
154 1
【Python】力扣刷题之有效的括号,利用字符串替换解题,用栈解决