OJ:LeetCode 65 Valid Number - 正则表达式

本文已参与「新人创作礼」活动,一起开启掘金创作之路

题目

65. Valid Number

valid number can be split up into these components (in order):

  1. decimal number or an integer.
  2. (Optional) An 'e' or 'E', followed by an integer.

decimal number can be split up into these components (in order):

  1. (Optional) A sign character (either '+' or '-').

  2. One of the following formats:

    1. One or more digits, followed by a dot '.'.
    2. One or more digits, followed by a dot '.', followed by one or more digits.
    3. A dot '.', followed by one or more digits.

An integer can be split up into these components (in order):

  1. (Optional) A sign character (either '+' or '-').
  2. One or more digits.

For example, all the following are valid numbers: ["2", "0089", "-0.1", "+3.14", "4.", "-.9", "2e10", "-90E3", "3e+7", "+6e-1", "53.5e93", "-123.456e789"], while the following are not valid numbers: ["abc", "1a", "1e", "e3", "99e2.5", "--6", "-+3", "95a54e53"].

Given a string s, return true if s is a valid number.

Example 1:

Input: s = "0"
Output: true

Example 2:

Input: s = "e"
Output: false

Example 3:

Input: s = "."
Output: false

Constraints:

  • 1 <= s.length <= 20
  • s consists of only English letters (both uppercase and lowercase), digits (0-9), plus '+', minus '-', or dot '.'.

题解

题目明确的给出了parse的规则,所以用正则最合适了,直接把题面翻译成正则表达式即可(滑稽
以下为AC代码,附赠一个题目自带的测试。

import re

class Solution:

    def isNumber_test(self, s: str) -> bool:
        ts = ["2", "0089", "-0.1", "+3.14", "4.", "-.9", "2e10", "-90E3", "3e+7", "+6e-1", "53.5e93", "-123.456e789"]
        fs = ["abc", "1a", "1e", "e3", "99e2.5", "--6", "-+3", "95a54e53"]
        print([self.isNumber_test(s) for s in ts])
        print([self.isNumber_test(s) for s in fs])

    def isNumber(self, s: str) -> bool:
        re_decimal = "(\+|-)?(([0-9]+\.[0-9]*)|(\.[0-9]+))"
        re_int = "(\+|-)?[0-9]+"
        re_real = "(({0})|({1}))((e|E)({1}))?".format(re_decimal, re_int)
        match_result = re.match(re_real, s)
        # print(match_result)
        try:
            return match_result.span() == (0, len(s))
        except Exception as e:
            return False
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值