九度OJ 1010

来源:互联网 发布:排序算法比较 编辑:程序博客网 时间:2024/05/20 03:41
题目描述:
读入两个小于100的正整数A和B,计算A+B.
需要注意的是:A和B的每一位数字由对应的英文单词给出.
输入:
测试输入包含若干测试用例,每个测试用例占一行,格式为"A + B =",相邻两字符串有一个空格间隔.当A和B同时为0时输入结束,相应的结果不要输出.
输出:
对每个测试用例输出1行,即A+B的值.
样例输入:
one + two =three four + five six =zero seven + eight nine =zero + zero =
样例输出:
39096


题目大意:这道题思路比较清晰,也就是求两个数的和。只不过两个数的形式是以英文的形式给出的。英文转数字比较简单,一个transfer函数就可以完成。这里的关键是根据用户输入的字符串得到两个操作数。其中,重点是用str.substr(a,b), a表示开始的位置,b表示字符串的长度。然后确定+号出现的位置,加号的位置前面是第一个操作数,后面是第二个操作数。最后还要看一下操作数的位数,即可。

#include <iostream>#include <cstring>using namespace std;int transfer(string str){    if(str == "one")        return 1;    if(str == "two")        return 2;    if(str == "three")        return 3;    if(str == "four")        return 4;    if(str == "five")        return 5;    if(str == "six")        return 6;    if(str == "seven")        return 7;    if(str == "eight")        return 8;    if(str == "nine")        return 9;    if(str == "zero")        return 0;    return -1;}int main(){    string str;    while(getline(cin,str)){        if(str == "zero + zero =")            break;        string strnum[5];     //保留分离出的数字        int k = 0;        int position[10];    //记录空格的位置        memset(position,0,sizeof(position));        int j=1;        for(int i=0;i<str.length();i++){            if(str[i] == '=')                break;            if(str[i] == ' '){                position[j] = i;                if(j == 1)                    strnum[k] = str.substr(position[j-1],position[j]-position[j-1]);                else                    strnum[k] = str.substr(position[j-1]+1,position[j]-position[j-1]-1);                k++;                j++;            }        }        int temp,num1,num2,result;        for(int i=0;i<5;i++){            if(strnum[i] == "+")                temp = i;     //i表示第一个操作数共有几位        }        if(temp == 1)          //表示第一个数共有一位            num1 = transfer(strnum[temp-1]);        else            num1 = transfer(strnum[temp-2])*10+transfer(strnum[temp-1]);        if(transfer(strnum[temp+2])>=0&&transfer(strnum[temp+2])<10)            num2 = transfer(strnum[temp+1])*10+transfer(strnum[temp+2]);        else            num2 = transfer(strnum[temp+1]);        result = num1 + num2;        cout<<result<<endl;    }    return 0;}



0 0
原创粉丝点击