【剑指Offer】53表示数值的字符串

本文介绍了一个函数,用于判断输入的字符串是否能表示一个数值,包括整数和小数。通过对字符串中的特殊字符如'e', 'E', '+', '-', '.'进行逻辑判断,实现了对多种可能的数值表示形式的支持。

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

题目描述

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

时间限制:1秒;空间限制:32768K;本题知识点:字符串

解题思路

本题难点在于充分考虑各种可能出现的异常情况。

# -*- coding:utf-8 -*-
class Solution:
    # s字符串
    def isNumeric(self, s):
        # write code here
        signe=0 #'e/E'符号标志位
        signd=0 #'.'符号标志位
        if not s:
            return False
        # 判断正负号
        if s[0]=='+' or s[0]=='-':
            s = s[1:]
        for i in range(len(s)):
            # 当前字符是'e'/'E'
            if s[i]=='e' or s[i]=='E':
                if signe==0: #'e'/'E'只能出现一次
                    signe = 1
                elif signe==1:
                    return False
                if i==len(s)-1: #'e'/'E'不能出现在最后
                    return False
            # 当前字符是'+'/'-'
            elif s[i]=='+' or s[i]=='-':
                if s[i-1]!='e' and s[i-1]!='E': #只能紧跟着'e'/'E'出现
                    return False
            # 当前字符是'.'
            elif s[i]=='.':
                if signd==0: #'.'只能出现一次
                    signd = 1
                elif signd==1:
                    return False
                if signe==1: #'.'不能出现在'e'/'E'后
                    return False
            # 当前字符是除数字和'+'/'-'/'e'/'E'/'.'以外的其他字符
            elif s[i]>'9' or s[i]<'0':
                return False
        # 排除以上异常情况,返回True
        return True

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值