剑指offer系列-面试题67. 把字符串转换成整数 (python)

1. 题目

写一个函数 StrToInt,实现把字符串转换成整数这个功能。不能使用 atoi 或者其他类似的库函数。

首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。

当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组合起来,作为该整数的正负号;假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数。

该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响。

注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换。

在任何情况下,若函数不能进行有效的转换时,请返回 0。

2. 解题思路

原文详情见 面试题67. 把字符串转换成整数(数字越界处理,清晰图解)
在这里插入图片描述

3. 代码实现

3.1 渣渣的

class Solution:
    def strToInt(self, s: str) -> int:
        """
        用ascii码,判断是否是数字
        +:43
        -:45
        0~10: 48 ~ 57
        """
        
        s = s.strip() # 1.去掉开头和结尾的空格

        start, flag = 0, 1 # 其实位置,符号
        if not s: return 0

        if s[0] == '+' or s[0] == '-': 
            start += 1
            flag = 44 - ord(s[0])

        i = start
        while i < len(s):
            ascii = ord(s[i])
            if (ascii < 48 or ascii > 57): # 表明不是数字
                break
            i += 1

        res = flag * int(s[start:i]) if s[start:i] else 0

        if res < -2 ** 31: res = -2**31
        if res > 2 ** 31 - 1: res = 2 ** 31 - 1

        return res

3.1 大佬的

class Solution:
    def strToInt(self, s: str) -> int:
        s = str.strip() # 删除首尾空格
        if not s: return 0 # 字符串为空则直接返回
        res, i, sign = 0, 1, 1
        int_max, int_min, bndry = 2 ** 31 - 1, -2 ** 31, 2 ** 31 // 10
        if s[0] == '-': sign = -1 # 保存负号
        elif s[0] != '+': i = 0 # 若无符号位,则需从 i = 0 开始数字拼接
        for c in s[i:]:
            if not '0' <= c <= '9' : break # 遇到非数字的字符则跳出
            if res > bndry or res == bndry and c > '7': return int_max if sign == 1 else int_min # 数字越界处理
            res = 10 * res + ord(c) - ord('0') # 数字拼接
        return sign * res

4. 总结

5. 参考文献

[1] 剑指offer丛书
[2] 剑指Offer——名企面试官精讲典型编程题
[3] 原文详情见 面试题67. 把字符串转换成整数(数字越界处理,清晰图解)

猜你喜欢

转载自blog.csdn.net/besmarterbestronger/article/details/106480739