前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >每日一道leetcode:8. 字符串转换整数 (atoi)

每日一道leetcode:8. 字符串转换整数 (atoi)

作者头像
felixzhao
发布于 2023-04-06 03:51:45
发布于 2023-04-06 03:51:45
42100
代码可运行
举报
文章被收录于专栏:null的专栏null的专栏
运行总次数:0
代码可运行

1. 题目(中等)

题目链接

请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。

函数 myAtoi(string s) 的算法如下:

读入字符串并丢弃无用的前导空格

检查下一个字符(假设还未到字符末尾)为正还是负号,读取该字符(如果有)。 确定最终结果是负数还是正数。 如果两者都不存在,则假定结果为正。

读入下一个字符,直到到达下一个非数字字符或到达输入的结尾。字符串的其余部分将被忽略。 将前面步骤读入的这些数字转换为整数(即,“123” -> 123, “0032” -> 32)。如果没有读入数字,则整数为 0 。必要时更改符号(从步骤 2 开始)。

如果整数数超过 32 位有符号整数范围 [−231, 231 − 1] ,需要截断这个整数,使其保持在这个范围内。具体来说,小于 −231 的整数应该被固定为 −231 ,大于 231 − 1 的整数应该被固定为 231 − 1 。

返回整数作为最终结果。

注意:

  • 本题中的空白字符只包括空格字符 ’ ’ 。
  • 除前导空格或数字后的其余字符串外,请勿忽略 任何其他字符。

示例 1:

输入:s = “42” 输出:42 解释:加粗的字符串为已经读入的字符,插入符号是当前读取的字符。 第 1 步:“42”(当前没有读入字符,因为没有前导空格) 第 2 步:“42”(当前没有读入字符,因为这里不存在 ‘-’ 或者 ‘+’) 第 3 步:“42”(读入 “42”) 解析得到整数 42 。 由于 “42” 在范围 [-231, 231 - 1] 内,最终结果为 42 。

示例 2:

输入:s = " -42" 输出:-42 解释: 第 1 步:" -42"(读入前导空格,但忽视掉) 第 2 步:" -42"(读入 ‘-’ 字符,所以结果应该是负数) 第 3 步:" -42"(读入 “42”) 解析得到整数 -42 。 由于 “-42” 在范围 [-231, 231 - 1] 内,最终结果为 -42 。

示例 3:

输入:s = “4193 with words” 输出:4193 解释: 第 1 步:“4193 with words”(当前没有读入字符,因为没有前导空格) 第 2 步:“4193 with words”(当前没有读入字符,因为这里不存在 ‘-’ 或者 ‘+’) 第 3 步:“4193 with words”(读入 “4193”;由于下一个字符不是一个数字,所以读入停止) 解析得到整数 4193 。 由于 “4193” 在范围 [-231, 231 - 1] 内,最终结果为 4193 。

提示:

  • 0 <= s.length <= 200
  • s 由英文字母(大写和小写)、数字(0-9)、’ ‘、’+‘、’-’ 和 ‘.’ 组成

2. 分析与解答

思路:字符串解析。分情况:

  • 去除字符串开始的空格
  • 判断正负号
  • 逐个判断是否为数字并将其转换成数字,注意判断是否越界

注意:中间遇到空格也是要退出的情形

代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
class Solution {
public:
    int myAtoi(string s) {
        int n = s.length();
        int res = 0;
        int index = 0;
        // 去除前置空格
        while (index < n) {
            if (s[index] == ' ') index++;
            else break;
        }
        // 从第一个非空格开始,判断是否是负数
        int p = 1;
        if (s[index] == '-') {
            p = -1;
            index ++;
        } else if (s[index] == '+') {
            index ++;
        }
        for (int i = index; i < n; i++) {
            if (isdigit(s[i])) {
                int add = s[i]-'0';
                if (res > (INT_MAX - add) / 10) {
                    return p == 1 ? INT_MAX : INT_MIN;
                } else {
                    res = res * 10 + add;
                }
            } else break;
        }
        return res * p;
    }
};
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-04-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
LeetCode(7-整数反转&&8-字符串转换整数 (atoi)&&9-回文数)
如果觉得UP写的不错的话,可以点击上方蓝字关注哦,后续会持续更新LeetCode题解.
萌萌哒的瓤瓤
2021/02/23
4720
LeetCode(7-整数反转&&8-字符串转换整数 (atoi)&&9-回文数)
LeetCode - #8 字符串转换整数 (atoi)
实现一个 func myAtoi(_ str: String) -> Int 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。
Swift社区
2021/12/06
4840
【力扣算法11】之 8. 字符串转换整数 (atoi) python
请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。 函数 myAtoi(string s) 的算法如下:
全栈若城
2024/02/29
2050
【力扣算法11】之 8. 字符串转换整数 (atoi) python
【剑指卷王】字符串转换成整数(atoi)的模拟实现
字符串转换成整数(atoi)的模拟实现 题目力扣链接:字符串转换整数 (atoi) 请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数) 函数 myAtoi(string s) 的算法如下: 读入字符串并丢弃无用的前导空格 检查下一个字符(假设还未到字符末尾)为正还是负号,读取该字符(如果有)。 确定最终结果是负数还是正数。 如果两者都不存在,则假定结果为正 读入下一个字符,直到到达下一个非数字字符或到达输
用户9645905
2022/11/30
2780
【剑指卷王】字符串转换成整数(atoi)的模拟实现
LeetCode 8. 字符串转换整数 (atoi)
首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。接下来的转化规则如下:
freesan44
2020/06/08
4640
【每日一题】【leetcode】15. 字符串-把字符串转换成整数
写一个函数 StrToInt,实现把字符串转换成整数这个功能。不能使用 atoi 或者其他类似的库函数。
aneutron
2022/08/10
1750
【LeetCode】8. 字符串转换整数 (atoi)
当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组合起来,作为该整数的正负号;假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数。
韩旭051
2020/06/23
5510
【LeetCode】8. 字符串转换整数 (atoi)
【力扣刷题】8. 字符串转换整数 (atoi)
请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。
jayjay
2022/11/02
5740
【力扣刷题】8. 字符串转换整数 (atoi)
LeetCode 刷题笔记——day 6
如果反转后整数超过 32 位的有符号整数的范围 [−231, 231 − 1] ,就返回 0。
h-t-m
2022/11/24
3710
LeetCode 刷题笔记——day 6
LeetCode 8. 字符串转换整数 (atoi)
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/string-to-integer-atoi 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
Michael阿明
2022/11/26
2200
LeetCode【8】-- 字符串转换整数
请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。
秦怀杂货店
2022/02/15
7100
☆打卡算法☆LeetCode 8、字符串转换整数 算法解析
链接:https://leetcode-cn.com/problems/string-to-integer-atoi/
恬静的小魔龙
2022/08/07
3470
☆打卡算法☆LeetCode 8、字符串转换整数  算法解析
【每日算法Day 89】手动实现字符串转整数(atoi)函数,你会吗?
首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。接下来的转化规则如下:
godweiyang
2020/04/14
4790
Leetcode算法系列| 8. 字符串转换整数 (atoi)
为了表示方便,我们可以使用int型来表示这4个状态,0表示start,1表示signed,2表示in_number,3表示end。 所以对应上面的自动机状态表格,在代码中可以使用二维int数组来表示:
游戏开发小Y
2024/01/18
1460
Leetcode算法系列| 8. 字符串转换整数 (atoi)
Leetcode-8.字符串转换整数 (atoi)
首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。接下来的转化规则如下:
悠扬前奏
2020/05/18
7030
【刷穿 LeetCode】8. 字符串转换整数 (atoi)
首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。接下来的转化规则如下:
宫水三叶的刷题日记
2021/02/20
4400
leetcode - 字符串转换整数 (atoi)
首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。接下来的转化规则如下:
江涛学编程
2021/01/28
7700
力扣7-整数反转&力扣8-字符串转换整数 (atoi)
原题链接:https://leetcode.cn/problems/reverse-integer/
WuShF
2023/02/19
3800
力扣7-整数反转&力扣8-字符串转换整数 (atoi)
字符串转换整数 (atoi)
难度:中等 来源:8. 字符串转换整数 请你来实现一个 atoi 函数,使其能将字符串转换成整数。 字符串包含的字符包括:数字、大小写字母、+、-、空格。 字符串能够转成整数必须满足如下要求: 字符串第一个字符必须是数字或者 +、- 符号之一; +、- 或者数字之间必须是连续的才能转成整数; 其他情况下无法进行有效转换的时候返回 0; 转换后的数字必须在 [ , - 1] 之间。 示例 1: 输入: "42" 输出: 42 示例 2: 输入: " -42" 输出: -42 解释: 第一个非空白
用户4456933
2021/06/01
1.8K0
被字节”装“到了,只要你能看”完“这题目,就算你过?
请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。
前端胖头鱼
2022/07/25
3950
被字节”装“到了,只要你能看”完“这题目,就算你过?
推荐阅读
相关推荐
LeetCode(7-整数反转&&8-字符串转换整数 (atoi)&&9-回文数)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验