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. 把字符串转换成整数(数字越界处理,清晰图解)