九度OJ 1010
2016-06-12 22:45
169 查看
题目描述:
读入两个小于100的正整数A和B,计算A+B.
需要注意的是:A和B的每一位数字由对应的英文单词给出.
输入:
测试输入包含若干测试用例,每个测试用例占一行,格式为"A + B =",相邻两字符串有一个空格间隔.当A和B同时为0时输入结束,相应的结果不要输出.
输出:
对每个测试用例输出1行,即A+B的值.
样例输入:
样例输出:
题目大意:这道题思路比较清晰,也就是求两个数的和。只不过两个数的形式是以英文的形式给出的。英文转数字比较简单,一个transfer函数就可以完成。这里的关键是根据用户输入的字符串得到两个操作数。其中,重点是用str.substr(a,b), a表示开始的位置,b表示字符串的长度。然后确定+号出现的位置,加号的位置前面是第一个操作数,后面是第二个操作数。最后还要看一下操作数的位数,即可。
读入两个小于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 =
样例输出:
3 90 96
题目大意:这道题思路比较清晰,也就是求两个数的和。只不过两个数的形式是以英文的形式给出的。英文转数字比较简单,一个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; }
相关文章推荐
- JS 把 String 转成 new Date()型
- ListView的使用技巧集合(五)
- Quartz与Spring强强联手,定时任务实现更容易
- 双端队列(Double-ended Queue)
- 类型限定词
- mongoose的基本操作(二)
- 安卓系统按键映射修改
- Bootstrap之表格checkbox复选框全选
- 理解MVC模式
- python的if语句
- Linux运维(数据库专题)面试题
- Android-银联支付开发
- 无锁队列的实现
- 无锁队列的实现
- 无锁队列的实现
- 从iOS端Facebook分享的预览效果到Open Graph Protocol(开放内容协议)
- HDU 1597 find the nth digit
- Linux应用编程之时间编程
- 冒泡排序 及其两次优化
- 第 5 章 内置函数