[ACM] hdu 1228 A+B (字符串处理)

2024-01-28 13:32
文章标签 字符串 处理 acm hdu 1228

本文主要是介绍[ACM] hdu 1228 A+B (字符串处理),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

A + B

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 11543    Accepted Submission(s): 6699


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


 

Source

 

浙大计算机研究生复试上机考试-2005年

 

解题思路:

以加号为界限,左右两个加数分别存到一个字符串里面,再在每个字符串中提取出来加数。

代码:

方法1:使用substr函数,手动判断空格

#include <iostream>
#include <string.h>
using namespace std;
int change(string str)//字符串转换成数字
{
int d;
if(str=="zero")
d=0;
else if(str=="one")
d=1;
else if(str=="two")
d=2;
else if(str=="three")
d=3;
else if(str=="four")
d=4;
else if(str=="five")
d=5;
else if(str=="six")
d=6;
else if(str=="seven")
d=7;
else if(str=="eight")
d=8;
else if(str=="nine")
d=9;
return d;
}
int main()
{
string exp;//输入的一行
string A,B;int a,b;//A,B分别代表加号左,右的数的字符串,a,b分别为两个加数的值
while(getline(cin,exp))
{
int len=exp.length();
int j;
int tap1,tap2;
for(j=0;j<len;j++)
{
if(exp[j]==' '&&exp[j+1]=='+')
tap1=j;//tap1为第一个数右边的空格
if(exp[j]==' '&&exp[j+1]=='=')
tap2=j;//tap2为第二个数右边的空格
}
A=exp.substr(0,tap1);//提取,开始位置为0,提取长度为tap1
B=exp.substr(tap1+3,tap2-tap1-3);
int lenA=A.length();
int lenB=B.length();
a=b=0;
int pre=-1;
for(int i=0;i<lenA;i++)
{
if(A[i]==' ')
{
a=a*10+change(A.substr(pre+1,i-pre-1));
pre=i;
}
if(i==lenA-1)//和空格的情况不太一样,要多读取一位
a=a*10+change(A.substr(pre+1,i-pre));
}
pre=-1;
for(int i=0;i<lenB;i++)
{
if(B[i]==' ')
{
b=b*10+change(B.substr(pre+1,i-pre-1));
pre=i;
}
if(i==lenB-1)
b=b*10+change(B.substr(pre+1,i-pre));
}
if(a==0&&b==0)
break;
cout<<a+b<<endl;
}
return 0;
}

方法2,3:(输入时,自动忽略空格,把每个单词放入到一个字符数组中)

代码1:

#include <iostream>
#include <stdio.h>
#include <string.h>
using namespace std;
char s[100][100];
int change(char str[])
{
int d;
if(str[0]=='z')//不能str=="zero"
d=0;
else if(str[0]=='o')
d=1;
else if(str[0]=='t'&&str[1]=='w')
d=2;
else if(str[0]=='t'&&str[1]=='h')
d=3;
else if(str[0]=='f'&&str[1]=='o')
d=4;
else if(str[0]=='f'&&str[1]=='i')
d=5;
else if(str[0]=='s'&&str[1]=='i')
d=6;
else if(str[0]=='s'&&str[1]=='e')
d=7;
else if(str[0]=='e')
d=8;
else if(str[0]=='n')
d=9;
return d;
}
int main()
{
int a,b;
int c = 0;
while(~scanf("%s", s[c])){//先输入第一个单词
c = 1;
char ch;
while(scanf("%s%c",s[c], &ch)){//以空格为界限,读入每个单词,字符数组不读空格
if(ch == '\n')//退出条件
break;
c++;
}
int ok=0;
a=b=0;
for(int i=0;i<c;i++)
{
if(s[i][0]=='+')
{
ok=1;
continue;
}
if(ok==0)
a=a*10+change(s[i]);
else if(ok==1)
b=b*10+change(s[i]);
}
if(a==0&&b==0)
break;
cout<<a+b<<endl;
c = 0;
}
return 0;
}


代码2:

#include <iostream>
#include <stdio.h>
#include <string.h>
using namespace std;
char s[100][100];
int change(char str[])
{
int d;
if(str[0]=='z')//不能str=="zero"
d=0;
else if(str[0]=='o')
d=1;
else if(str[0]=='t'&&str[1]=='w')
d=2;
else if(str[0]=='t'&&str[1]=='h')
d=3;
else if(str[0]=='f'&&str[1]=='o')
d=4;
else if(str[0]=='f'&&str[1]=='i')
d=5;
else if(str[0]=='s'&&str[1]=='i')
d=6;
else if(str[0]=='s'&&str[1]=='e')
d=7;
else if(str[0]=='e')
d=8;
else if(str[0]=='n')
d=9;
return d;
}
int main()
{
while(1)
{
char ch;
int a,b;
int c=0;
while(scanf("%s%c",s[c],&ch))//输入每个单词
{
if(ch=='\n')
break;
c++;
}
int ok=0;
a=b=0;
for(int i=0;i<c;i++)//s[c]里面在该题存的是”=“,没用
{
if(s[i][0]=='+')
{
ok=1;
continue;
}
if(ok==0)
a=a*10+change(s[i]);
else if(ok==1)
b=b*10+change(s[i]);
}
if(a==0&&b==0)
break;
cout<<a+b<<endl;
}
return 0;
}



 

这篇关于[ACM] hdu 1228 A+B (字符串处理)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/653764

相关文章

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

解决docker目录内存不足扩容处理方案

《解决docker目录内存不足扩容处理方案》文章介绍了Docker存储目录迁移方法:因系统盘空间不足,需将Docker数据迁移到更大磁盘(如/home/docker),通过修改daemon.json配... 目录1、查看服务器所有磁盘的使用情况2、查看docker镜像和容器存储目录的空间大小3、停止dock

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

5 种使用Python自动化处理PDF的实用方法介绍

《5种使用Python自动化处理PDF的实用方法介绍》自动化处理PDF文件已成为减少重复工作、提升工作效率的重要手段,本文将介绍五种实用方法,从内置工具到专业库,帮助你在Python中实现PDF任务... 目录使用内置库(os、subprocess)调用外部工具使用 PyPDF2 进行基本 PDF 操作使用

分析 Java Stream 的 peek使用实践与副作用处理方案

《分析JavaStream的peek使用实践与副作用处理方案》StreamAPI的peek操作是中间操作,用于观察元素但不终止流,其副作用风险包括线程安全、顺序混乱及性能问题,合理使用场景有限... 目录一、peek 操作的本质:有状态的中间操作二、副作用的定义与风险场景1. 并行流下的线程安全问题2. 顺

Python异常处理之避免try-except滥用的3个核心原则

《Python异常处理之避免try-except滥用的3个核心原则》在Python开发中,异常处理是保证程序健壮性的关键机制,本文结合真实案例与Python核心机制,提炼出避免异常滥用的三大原则,有需... 目录一、精准打击:只捕获可预见的异常类型1.1 通用异常捕获的陷阱1.2 精准捕获的实践方案1.3

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

Python动态处理文件编码的完整指南

《Python动态处理文件编码的完整指南》在Python文件处理的高级应用中,我们经常会遇到需要动态处理文件编码的场景,本文将深入探讨Python中动态处理文件编码的技术,有需要的小伙伴可以了解下... 目录引言一、理解python的文件编码体系1.1 Python的IO层次结构1.2 编码问题的常见场景二

Java 字符串操作之contains 和 substring 方法最佳实践与常见问题

《Java字符串操作之contains和substring方法最佳实践与常见问题》本文给大家详细介绍Java字符串操作之contains和substring方法最佳实践与常见问题,本文结合实例... 目录一、contains 方法详解1. 方法定义与语法2. 底层实现原理3. 使用示例4. 注意事项二、su