Leetcode:字符串转换整数 (atoi)

2024-06-02 19:20

本文主要是介绍Leetcode:字符串转换整数 (atoi),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:8. 字符串转换整数 (atoi) - 力扣(LeetCode)

普通版本(条件限制)

class Solution {
public:int myAtoi(string s) {int res = 0;int i = 0;int flag = 1;//假设整数为正while(s[i] == ' ')//跳过空格{i++;}if(s[i] == '-')//如果空格后的符号为-则将flag变为-1{flag = -1;}if(s[i] == '+' || s[i] == '-')//更新完flag后继续向后走(不论+ -){i++;}//没有走到末尾 && 当前位置的字符还是“整数字符”就继续循环while(i < s.size() && isdigit(s[i])){int r = s[i] - '0';//将当前位置的字符转为整数//先判断后插入if(res > INT_MAX / 10 ||(res == INT_MAX / 10 && r > 7))//判断当前已经获取的新的数字是否越界{return flag > 0 ? INT_MAX : INT_MIN;//越界后,若该数原本是负数就返回INT_MIN是正数就返回INT_MAX}res = res * 10 + r;//每次*10向前移动,使得r插入新数字i++;}return flag > 0 ? res : -res;//获取完毕后,原本该数是正数就返回res,是负数就返回(-1) * res}
};

优化版本(确定有限状态机,待补充) 

抽象版本(巧妙运用cin)

class Solution {
public:int myAtoi(string s) {stringstream liu(s);int n=0;liu>>n;//通过>>操作符,stringstream类型的对象liu会尝试从字符串流中提取一个整数,并将其存储在变量n中return n;}
};
  • 文档:stringstream - C++ Reference (cplusplus.com)
  • std::stringstream是C++标准库中的一个类,它允许将字符串作为流来处理,可以方便地进行字符串和其他数据类型(比如整数、浮点数)之间的转换

读取规则:

①忽略字符串开头的空格,直到遇到第一个非空格字符为止

②遇到- / +符号时,它会识别这是一个负 / 正数

③继续读取数字字符,直到遇到非数字字符为止(042的0也会读取,出去的时候会消去)

④将这些数字字符转换为整数,并考虑之前识别的负号

~over~

这篇关于Leetcode:字符串转换整数 (atoi)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

python中字符串拼接的几种方法及优缺点对比详解

《python中字符串拼接的几种方法及优缺点对比详解》在Python中,字符串拼接是常见的操作,Python提供了多种方法来拼接字符串,每种方法有其优缺点和适用场景,以下是几种常见的字符串拼接方法,需... 目录1. 使用 + 运算符示例:优缺点:2. 使用&nbsjsp;join() 方法示例:优缺点:3

使用C语言实现交换整数的奇数位和偶数位

《使用C语言实现交换整数的奇数位和偶数位》在C语言中,要交换一个整数的二进制位中的奇数位和偶数位,重点需要理解位操作,当我们谈论二进制位的奇数位和偶数位时,我们是指从右到左数的位置,本文给大家介绍了使... 目录一、问题描述二、解决思路三、函数实现四、宏实现五、总结一、问题描述使用C语言代码实现:将一个整

java字符串数字补齐位数详解

《java字符串数字补齐位数详解》:本文主要介绍java字符串数字补齐位数,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java字符串数字补齐位数一、使用String.format()方法二、Apache Commons Lang库方法三、Java 11+的St

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示