【Leetcode8】字符串转换整数

题目描述

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

解题思路

1、对于输入左边有空字符的,首先去掉空字符
2、第一个非空字符必须为数字或者正负号
3、第一个非空字符不为数字或者正负号则返回0
4、输入值不在区间[ − 2 31 -2^{31} 231, 2 31 − 1 2^{31}-1 2311]之间的,该值大于 2 31 − 1 2^{31}-1 2311则返回2147483647,小于 − 2 31 -2^{31} 231的则返回-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:一个数字
+:前面一个字符的一个或多个

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值