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

相关文章

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

在Java中将XLS转换为XLSX的实现方案

《在Java中将XLS转换为XLSX的实现方案》在本文中,我们将探讨传统ExcelXLS格式与现代XLSX格式的结构差异,并为Java开发者提供转换方案,通过了解底层原理、性能优势及实用工具,您将掌握... 目录为什么升级XLS到XLSX值得投入?实际转换过程解析推荐技术方案对比Apache POI实现编程

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

使用Python实现网页表格转换为markdown

《使用Python实现网页表格转换为markdown》在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,本文将使用Python编写一个网页表格转Markdown工具,需... 在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,以便在文档、邮件或

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

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

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

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

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

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

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

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