【剑指offer】表示数值的字符串【python】

本文深入探讨了数字格式验证算法的实现细节,包括如何通过遍历字符串检查合法的科学计数法表示。文章详细解释了在遇到'e'、'.'、'+'、'-'等特殊字符时的处理规则,确保了算法的正确性和健壮性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述

  • 数字的格式可以用A[.[B]][E|eC]或者.B[E|eC]表示,其中A和C都是整数(可以有符号也可以没有),B是一个无符号数
  • 采用遍历的方式发现很困难的时候,需要采取聪明一点的方式
  • 如果遍历到e,那么之前不能有e,并且e不能再末尾
  • 如果遍历到.,那么之前不能有.,并且之前不能有e
  • 如果遍历到符号,那么如果之前有符号,只能够出现在e的后面,如果之前没符号,那么符号只能出现在第一位,或者出现在e的后面
  • 如果遍历到不是上面所有的符号和0~9,返回False
class Solution:
    # s字符串
    def isNumeric(self, s):
        hasE = False
        hasDot = False
        hasSign = False
        for i in range(len(s)):
            if s[i] == 'e' or s[i] == 'E':
                if hasE or i == len(s) - 1:
                    return False
                hasE = True
            elif s[i] == '.':
                if hasDot or hasE:
                    return False
                hasDot = True
            elif s[i] == '+' or s[i] == '-':
                if hasSign and s[i - 1] != 'e' and s[i - 1] != 'E':
                    return False
                if not hasSign:
                    if i != 0 and s[i - 1] != 'e' and s[i - 1] != 'E':
                        return False
                hasSign = True
            else:
                if s[i] < '0' or s[i] > '9':
                    return False
        return True
print(Solution().isNumeric('12e'))

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值