Leetcode 65. Valid Number 有效数字

Leetcode 65. Valid Number 有效数字

标签: Leetcode


题目地址:https://leetcode-cn.com/problems/valid-number/

题目描述

验证给定的字符串是否可以解释为十进制数字。

例如:

"0" => true
" 0.1 " => true
"abc" => false
"1 a" => false
"2e10" => true
" -90e3   " => true
" 1e" => false
"e3" => false
" 6e-1" => true
" 99e2.5 " => false
"53.5e93" => true
" --6 " => false
"-+3" => false
"95a54e53" => false

说明: 我们有意将问题陈述地比较模糊。在实现代码之前,你应当事先思考所有可能的情况。这里给出一份可能存在于有效十进制数字中的字符列表:

  • 数字 0-9
  • 指数 - "e"
  • 正/负号 - "+"/"-"
  • 小数点 - "."

当然,在输入中,这些字符的上下文也很重要。

更新于 2015-02-10:
C++函数的形式已经更新了。如果你仍然看见你的函数接收 const char * 类型的参数,请点击重载按钮重置你的代码。

算法思想

这道题目主要是理清楚,要明白如果一个数是数字那么其要满足的规则,只要弄懂了这个,直接写规则就行了。从题目以及常识可以得出一个数字满足如下的几点:

  1. 开头可能有正负号

  2. 如果出现e 那么之前必须要有数字出现,并且之前没有过e

  3. 如果出现了.,那么也同样的之前不能有过.并且不能在e后面出现。

  4. 如果在非开头的位置出现了+,-,那么必须要紧邻着e

通过上面的条件可以筛选出几个变量用来标记,用isNum来标记当前是否为有效数字,用hasE标记是否出现过了e,用hasDot标记是否出现过了.,所以我们遍历的时候,如果遇见的字符是0-9,则直接标记isNum = True,如果遇见的是e,则先判断之前是否为有效数字以及是否出现过e,如果之前不是有效数字或者出现过e则返回False,否则可以把hasE = True以及isNum = False.同样的如果遇见的是.,需要判断之前是否出现过.以及e,如果都没有,可以把hasDot置位True。把上面的4个条件依次判断一下即可。

python代码


class Solution(object):
    def isNumber(self, s):
        """
        :type s: str
        :rtype: bool
        """
        s = s.strip() #去空格
        n = len(s)
        if n==0:return False
        i = 0
        isNum = False # 当前0-i是否为有效数字
        hasE = False # 到当前位置是否有e出现(因为只能出现一次)
        hasDot = False # 到当前位置是否有.出现(因为只能出现一次)
        if s[i]=='-' or s[i]=='+':i=+1 # 开始的时候可能有正负号,先判断
        while i<n:
            if s[i]>='0' and s[i]<='9': isNum = True #是数字
            elif s[i]=='e':
                if not isNum or hasE:return False # 当前还没有数字(E不能出现在开头)或者已经有了E
                hasE = True
                isNum = False #如果出现E了,后面没有数字,则为False
            elif s[i]=='.':
                if hasDot or hasE:return False # .只能出现一次,并且不能在e后面,可以在e前面
                hasDot = True
            elif s[i]=='-' or s[i]=='+':
                if s[i-1]!='e':return False # 第一个代表正负号的加减刚开始已经过滤了,所以后面的+-只能是E后面的
            else:return False # 其他字符
            i+=1
        return isNum

参考:

https://blog.csdn.net/jhbxlx/article/details/38108785

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值