[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

相关文章

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

使用C++将处理后的信号保存为PNG和TIFF格式

《使用C++将处理后的信号保存为PNG和TIFF格式》在信号处理领域,我们常常需要将处理结果以图像的形式保存下来,方便后续分析和展示,C++提供了多种库来处理图像数据,本文将介绍如何使用stb_ima... 目录1. PNG格式保存使用stb_imagephp_write库1.1 安装和包含库1.2 代码解

C#使用DeepSeek API实现自然语言处理,文本分类和情感分析

《C#使用DeepSeekAPI实现自然语言处理,文本分类和情感分析》在C#中使用DeepSeekAPI可以实现多种功能,例如自然语言处理、文本分类、情感分析等,本文主要为大家介绍了具体实现步骤,... 目录准备工作文本生成文本分类问答系统代码生成翻译功能文本摘要文本校对图像描述生成总结在C#中使用Deep

C#从XmlDocument提取完整字符串的方法

《C#从XmlDocument提取完整字符串的方法》文章介绍了两种生成格式化XML字符串的方法,方法一使用`XmlDocument`的`OuterXml`属性,但输出的XML字符串不带格式,可读性差,... 方法1:通过XMLDocument的OuterXml属性,见XmlDocument类该方法获得的xm

Spring Boot 整合 ShedLock 处理定时任务重复执行的问题小结

《SpringBoot整合ShedLock处理定时任务重复执行的问题小结》ShedLock是解决分布式系统中定时任务重复执行问题的Java库,通过在数据库中加锁,确保只有一个节点在指定时间执行... 目录前言什么是 ShedLock?ShedLock 的工作原理:定时任务重复执行China编程的问题使用 Shed

Redis如何使用zset处理排行榜和计数问题

《Redis如何使用zset处理排行榜和计数问题》Redis的ZSET数据结构非常适合处理排行榜和计数问题,它可以在高并发的点赞业务中高效地管理点赞的排名,并且由于ZSET的排序特性,可以轻松实现根据... 目录Redis使用zset处理排行榜和计数业务逻辑ZSET 数据结构优化高并发的点赞操作ZSET 结

微服务架构之使用RabbitMQ进行异步处理方式

《微服务架构之使用RabbitMQ进行异步处理方式》本文介绍了RabbitMQ的基本概念、异步调用处理逻辑、RabbitMQ的基本使用方法以及在SpringBoot项目中使用RabbitMQ解决高并发... 目录一.什么是RabbitMQ?二.异步调用处理逻辑:三.RabbitMQ的基本使用1.安装2.架构

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过