【Leetcode8】字符串转换整数

题目描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

解题思路

1、对于输入左边有空字符的,首先去掉空字符
2、第一个非空字符必须为数字或者正负号
3、第一个非空字符不为数字或者正负号则返回0
4、输入值不在区间[ 2 31 -2^{31} , 2 31 1 2^{31}-1 ]之间的,该值大于 2 31 1 2^{31}-1 则返回2147483647,小于 2 31 -2^{31} 的则返回-2147483648

python代码

class Solution:
    def myAtoi(self, s: str) -> int:
        INT_MAX = 2147483647
        INT_MIN = -2147483648
        str = str.lstrip()      #清除左边多余的空格
        num = num_re.findall('^[\+\-]?\d+',str)   #设置规则,查找匹配的内容
        num = int(*num) #由于返回的是个列表,解包并且转换成整数
        return max(min(num,INT_MAX),INT_MIN)    #返回值

^:匹配字符串开头
[+-]:代表一个+字符或-字符
?:前面一个字符可有可无
\d:一个数字
+:前面一个字符的一个或多个

发布了56 篇原创文章 · 获赞 1 · 访问量 1678

猜你喜欢

转载自blog.csdn.net/weixin_44549556/article/details/105189569
今日推荐