请你来实现一个 myAtoi(string s)
函数,使其能将字符串转换成一个 32 位有符号整数。
函数 myAtoi(string s)
的算法如下:
- 空格:读入字符串并丢弃无用的前导空格(
" "
) - 符号:检查下一个字符(假设还未到字符末尾)为
'-'
还是'+'
。如果两者都不存在,则假定结果为正。 - 转换:通过跳过前置零来读取该整数,直到遇到非数字字符或到达字符串的结尾。如果没有读取数字,则结果为0。
- 舍入:如果整数数超过 32 位有符号整数范围
[−231, 231 − 1]
,需要截断这个整数,使其保持在这个范围内。具体来说,小于−231
的整数应该被舍入为−231
,大于231 − 1
的整数应该被舍入为231 − 1
。
返回整数作为最终结果。
示例 1:
输入:s = "42"
输出:42
解释:加粗的字符串为已经读入的字符,插入符号是当前读取的字符。
带下划线线的字符是所读的内容,插入符号是当前读入位置。 第 1 步:"42"(当前没有读入字符,因为没有前导空格) ^ 第 2 步:"42"(当前没有读入字符,因为这里不存在 '-' 或者 '+') ^ 第 3 步:"42"(读入 "42") ^
示例 2:
输入:s = " -042"
输出:-42
解释:
第 1 步:" -042"(读入前导空格,但忽视掉) ^ 第 2 步:" -042"(读入 '-' 字符,所以结果应该是负数) ^ 第 3 步:" -042"(读入 "042",在结果中忽略前导零) ^
示例 3:
输入:s = "1337c0d3"
输出:1337
解释:
第 1 步:"1337c0d3"(当前没有读入字符,因为没有前导空格) ^ 第 2 步:"1337c0d3"(当前没有读入字符,因为这里不存在 '-' 或者 '+') ^ 第 3 步:"1337c0d3"(读入 "1337";由于下一个字符不是一个数字,所以读入停止) ^
示例 4:
输入:s = "0-1"
输出:0
解释:
第 1 步:"0-1" (当前没有读入字符,因为没有前导空格) ^ 第 2 步:"0-1" (当前没有读入字符,因为这里不存在 '-' 或者 '+') ^ 第 3 步:"0-1" (读入 "0";由于下一个字符不是一个数字,所以读入停止) ^
示例 5:
输入:s = "words and 987"
输出:0
解释:
读取在第一个非数字字符“w”处停止。
提示:
0 <= s.length <= 200
s
由英文字母(大写和小写)、数字(0-9
)、' '
、'+'
、'-'
和'.'
组成
用一行代码实现的方法
class Solution(object):
def myAtoi(self, s):
"""
:type s: str
:rtype: int
"""
return max(min(int(*re.findall('^[\+\-]?\d+', s.lstrip())), 2**31 - 1), -2**31)
这段代码实现了从字符串 s
中提取一个整数,并确保这个整数在 32 位有符号整数的范围内(即从 -2**31
到 2**31 - 1
)。下面我将详细解释这段代码的每个部分:
-
s.lstrip()
: 这个方法用于去除字符串开头的空白字符(包括空格、制表符等)。 -
re.findall('^[\+\-]?\d+', s.lstrip())
:re.findall
是 Python 的正则表达式模块中的一个方法,用于找到所有匹配的字符串。^[\+\-]?\d+
是一个正则表达式:^
表示匹配字符串的开头。[\+\-]?
表示可选的一个正负号。\d+
表示一个或多个数字。
- 这段正则表达式会匹配字符串开头的一个整数(可以带有正负号)。
-
int(...)
: 将正则表达式找到的字符串转换为整数。 -
min(int(...), 2 ** 31 - 1)
: 这个部分确保整数不会超过 32 位有符号整数的最大值2 ** 31 - 1
,即2147483647
。 -
max(..., -2 ** 31)
: 这个部分确保整数不会小于 32 位有符号整数的最小值-2 ** 31
,即-2147483648
。
整段代码的作用是:从字符串 s
中提取一个有效的整数,并将其限制在 32 位有符号整数的范围内。
例如,假设输入字符串为 " -123abc"
,处理步骤如下:
s.lstrip()
去除前导空白字符,得到"-123abc"
.- 正则表达式
^[\+\-]?\d+
匹配开头的"-123"
. int(...)
将"-123"
转换为整数-123
.- 然后通过
min(..., 2147483647)
和max(..., -2147483648)
确保整数在 32 位有符号整数的范围内。最终返回-123
.
如果将一行拆分,可以写成这样
class Solution:
def myAtoi(self, s: str) -> int:
stripped_string = s.lstrip()
# 使用正则表达式匹配字符串开头的一个整数(可以带有正负号)
matched_number = re.findall('^[\+\-]?\d+', stripped_string)
# 将匹配的结果转换为整数,并限制在 32 位有符号整数的范围内
result = max(min(int(*matched_number), 2 ** 31 - 1), -2 ** 31)
return result