利用正则表达式可以很方便解决:
正则式为:
r"^[\+\-]?[0-9]+"
其中:
- ^表示从开头开始匹配
- [\+\-]表示字符可以是+ or -
- ?表示可以没有+ or -
- [0-9]代表从0-9的数字
- +代表任意位数
正则式好久没用到了就忘了,还是要复习一下,毕竟对于字符串问题很容易解决
class Solution:
def myAtoi(self, str: str) -> int:
import re
str = re.findall(r"^[\+\-]?[0-9]+", str.lstrip())
num = int(str[0]) if str else 0
return max(-2 ** 31, min(2 ** 31 - 1, num))
正则表达式解析整数
本文介绍了一种使用正则表达式解析字符串中整数的方法,包括正负号的可选性和数字的有效范围。通过Python实现,展示了如何将字符串转换为整数,并确保其在32位有符号整数范围内。
2745

被折叠的 条评论
为什么被折叠?



