九度OJ-1010:A + B

本文介绍了一种算法,该算法能够将英文表述的数字转换为整数值,并通过实例演示了如何实现两个英文数字相加的功能。算法首先解析输入字符串中的英文数字,将其转换为对应的整数,然后进行加法运算。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


题目描述:
读入两个小于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年浙江大学计算机及软件工程研究生机试真题
答疑:
解题遇到问题?分享解题心得?讨论本题请访问: http://t.jobdu.com/thread-7734-1-1.html


#include <cstdio>
#include <cstring>
using namespace std;
char form[10][10]={"zero","one","two","three","four","five","six","seven","eight","nine"};

int char2int (){
	int sum=0;
	char str[10];
	while (scanf("%s",str),strcmp(str,"+")!=0&&strcmp(str,"=")!=0){
		sum*=10;
		for (int i=0;i<10;i++){
			if (strcmp(form[i],str)==0){
				sum+=i;
				break;
			}
		}
	}
	return sum;
}
int main(){
	int a,b;
	while (true){
		a=char2int();
		b=char2int();
		if (!(a||b)){
			break;
		}
		printf("%d\n",a+b);
	}
	return true;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值