剑指offer:Python 表示数值的字符串 一行代码搞定

题目描述

请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100",“5e2”,"-123",“3.1416"和”-1E-16"都表示数值。 但是"12e",“1a3.14”,“1.2.3”,"±5"和"12e+4.3"都不是。

思路及Python实现

思路一
  • e后的数表示10的多少次方。1.810524e10就表示1.810524乘以10的10次方。数字很大的数,一般我们可以用E数表示,例如6230000000000;我们可以用6.23E12表示,而它表示的是将6.23×10^12 E数形式6.23E12,代表将数字6.23中6后面的小数点向右移去12位。

  • 在给出的可能出现的字符串中,有三个字符比较特殊,“+ - ”,“e or E”,“.”,需要对着几种情况进行考虑:
    (1)“+ - ”只能出现在字符串首或者字符“e or E”后面,且不能出现在最后一位。
    (2)“.”不能出现在字符串首,也不能出现在字符串尾部,也不能出现在字符“e or E”后面,且不能出现两次。
    (3)“e or E”不能出现两次且不能出现在字符串尾部。
    (4)除了0–9和上面三个字符,不能出现其他的字符。在具体的实现过程中,由于“e or E”和“.”不能出现两次,那么我们可以设置两个表示这两个字符能否在出现的标志。

class Solution:
    # s字符串
    def isNumeric(self, s):  # 主要是dot和E不能随便出现
        allow_dot = True
        allow_e = True
        for i in range(len(s)):
            if s[i] in "+ -" and (i == 0 or s[i - 1] in "Ee") and i != (len(s) - 1):
                continue
            elif allow_dot and s[i] == ".":
            	# 若当前字符为“.”,那么后面就不能出现“.”了,修改标志为False,“eE”同理。
                allow_dot = False  
                if i == 0 or i == (len(s) - 1) or allow_e is False:
                    return False
            elif allow_e and s[i] in "Ee":
                allow_e = False
                if i == len(s) - 1:
                    return False
            elif s[i] not in "0123456789":  # 最后验证是否出现了其他字符
                return False
        return True
思路二:正则表达式
  • 正则表达式,直接一行搞定,但是其中的妙处要好好学,详情可以看我之前写的的正则的用法详解:正则表达式剖析详解
import re
class Solution:
    def isNumeric(self, s):
        return re.search(r"^[+-]?\d*(\.\d*)?([eE][+-]?\d+)?$", s)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值