[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 web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

Python处理大量Excel文件的十个技巧分享

《Python处理大量Excel文件的十个技巧分享》每天被大量Excel文件折磨的你看过来!这是一份Python程序员整理的实用技巧,不说废话,直接上干货,文章通过代码示例讲解的非常详细,需要的朋友可... 目录一、批量读取多个Excel文件二、选择性读取工作表和列三、自动调整格式和样式四、智能数据清洗五、

golang float和科学计数法转字符串的实现方式

《golangfloat和科学计数法转字符串的实现方式》:本文主要介绍golangfloat和科学计数法转字符串的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望... 目录golang float和科学计数法转字符串需要对float转字符串做处理总结golang float

Python如何判断字符串中是否包含特殊字符并替换

《Python如何判断字符串中是否包含特殊字符并替换》这篇文章主要为大家详细介绍了如何使用Python实现判断字符串中是否包含特殊字符并使用空字符串替换掉,文中的示例代码讲解详细,感兴趣的小伙伴可以了... 目录python判断字符串中是否包含特殊字符方法一:使用正则表达式方法二:手动检查特定字符Pytho

SpringBoot如何对密码等敏感信息进行脱敏处理

《SpringBoot如何对密码等敏感信息进行脱敏处理》这篇文章主要为大家详细介绍了SpringBoot对密码等敏感信息进行脱敏处理的几个常用方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录​1. 配置文件敏感信息脱敏​​2. 日志脱敏​​3. API响应脱敏​​4. 其他注意事项​​总结

Python使用python-docx实现自动化处理Word文档

《Python使用python-docx实现自动化处理Word文档》这篇文章主要为大家展示了Python如何通过代码实现段落样式复制,HTML表格转Word表格以及动态生成可定制化模板的功能,感兴趣的... 目录一、引言二、核心功能模块解析1. 段落样式与图片复制2. html表格转Word表格3. 模板生

Python Pandas高效处理Excel数据完整指南

《PythonPandas高效处理Excel数据完整指南》在数据驱动的时代,Excel仍是大量企业存储核心数据的工具,Python的Pandas库凭借其向量化计算、内存优化和丰富的数据处理接口,成为... 目录一、环境搭建与数据读取1.1 基础环境配置1.2 数据高效载入技巧二、数据清洗核心战术2.1 缺失

SpringBoot项目中Redis存储Session对象序列化处理

《SpringBoot项目中Redis存储Session对象序列化处理》在SpringBoot项目中使用Redis存储Session时,对象的序列化和反序列化是关键步骤,下面我们就来讲讲如何在Spri... 目录一、为什么需要序列化处理二、Spring Boot 集成 Redis 存储 Session2.1

MySQL 字符串截取函数及用法详解

《MySQL字符串截取函数及用法详解》在MySQL中,字符串截取是常见的操作,主要用于从字符串中提取特定部分,MySQL提供了多种函数来实现这一功能,包括LEFT()、RIGHT()、SUBST... 目录mysql 字符串截取函数详解RIGHT(str, length):从右侧截取指定长度的字符SUBST

Python将字符串转换为小写字母的几种常用方法

《Python将字符串转换为小写字母的几种常用方法》:本文主要介绍Python中将字符串大写字母转小写的四种方法:lower()方法简洁高效,手动ASCII转换灵活可控,str.translate... 目录一、使用内置方法 lower()(最简单)二、手动遍历 + ASCII 码转换三、使用 str.tr