题目1010:A + B 九度OJ
2017-04-26 20:40
218 查看
题目1010:A + B
时间限制:1 秒
内存限制:32 兆
特殊判题:否
提交:8983
解决:4658
题目描述:
读入两个小于100的正整数A和B,计算A+B.
需要注意的是:A和B的每一位数字由对应的英文单词给出.
输入:
测试输入包含若干测试用例,每个测试用例占一行,格式为"A + B =",相邻两字符串有一个空格间隔.当A和B同时为0时输入结束,相应的结果不要输出.
输出:
对每个测试用例输出1行,即A+B的值.
样例输入:
样例输出:
来源:2005年浙江大学计算机及软件工程研究生机试真题
时间限制:1 秒
内存限制:32 兆
特殊判题:否
提交:8983
解决:4658
题目描述:
读入两个小于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
来源:2005年浙江大学计算机及软件工程研究生机试真题
#include <cstdio> #include <iostream> #include <cstring> using namespace std; string str[]={"zero","one","two","three","four","five","six","seven","eight","nine"}; int checkNum(string &x){ for(int i=0;i<10;i++){ if(x==str[i])return i; } return 0; } int main(){ string a,b,plustag,equaltag; while(cin>>a){ int num1=0,num2=0; num1=checkNum(a); cin>>plustag; if(plustag!="+"){ num1=checkNum(plustag)+num1*10; cin>>plustag; } //cout<<"num1= "<<num1<<endl; cin>>b; num2=checkNum(b); cin>>equaltag; if(equaltag!="="){ num2=checkNum(equaltag)+num2*10; cin>>equaltag; } //cout<<"num2= "<<num2<<endl; if(num1==0&&num2==0)break; cout<<num1+num2<<endl; } return 0; }
相关文章推荐
- 九度OJ 题目1010:A + B
- 九度OJ—题目1010:A + B
- 九度oj 题目1467:二叉排序树
- 九度OJ题目1172:哈夫曼树
- 九度OJ题目1144:Freckles
- 九度OJ-题目1502:最大值最小化
- 九度OJ-题目1049 字符串去特定字符
- 九度OJ-题目1505:两个链表的第一个公共结点
- 九度OJ--题目1004:Median
- 九度OJ 题目1437:To Fill or Not to Fill
- 九度OJ 题目1138:进制转换
- 九度OJ 题目1130:日志排序
- 九度OJ 题目1147:Jugs
- 九度oj 题目1015:还是A+B 【ZJU2006考研机试题1】
- 九度oj 题目1026:又一版 A+B 【ZJU2008考研机试题1】
- 九度OJ 题目1135:字符串排序
- 【剑指Offer面试编程题】题目1510:替换空格--九度OJ
- 九度OJ 题目15:最大子向量和
- 九度OJ 题目1189:还是约瑟夫环
- 【剑指Offer面试编程题】题目1513:二进制中1的个数--九度OJ