python 整数转字符串_16、atoi-整数字符串转整数-leetcode8-中等

8abc2ee84d6d5fdf93e451af863cbccf.png

01243fb4b650774cf6a24bfe79cfde54.png

思路:借助正则表达式。

class Solution:
    def myAtoi(self, s: str) -> int:
        import re
        pattern = re.compile(r'^[-+]?d+') # 生成pattern
        s = s.lstrip() #去除左侧空格
        num_str = pattern.findall(s) #找到pattern,返回一个list
        num = int(*num_str) #用*将list解包
        return max(min(num, 2**31-1), -2**31) #界限处理:小于最大的有符号正整数,然后大于最小的有符号负整数

正则表达式:

^用法:限定开头,如 ^A会匹配"An e"中的A,但是不会匹配"ab A"中的A,此处用以限定只匹配从左侧字符串开头的数字字符串,因此findall()返回的列表最多一个元素。
[]用法:是定义匹配的字符范围。
?用法:匹配零次或一次。
d+用法:匹配多个数字。

compile() 函数用于编译正则表达式,生成一个正则表^达式( Pattern )对象。

findall()在字符串中找到正则表达式所匹配的所有子串,并返回一个列表,如果没有找到匹配的,则返回空列表。

lstrip()去除字符串左侧空格。

function(*list)*表示对list进行解包。

python的解包可以这样来理解:把元素给拆分并把其赋值给自己所需要的变量,因此元素应该是一个可迭代对象。

max(min(num, 2**31-1), -2**31) #界限处理:num应该小于最大的有符号正整数,然后大于最小的有符号负整数。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值