【剑指offer刷题笔记】表示数值的字符串

题目描述:

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

 

题目分析:

这道题目基本不涉及算法的知识,主要考察对多种情况考虑的全面性。

最开始拿到的时候大致看了看,感觉可能出现情况极其的多。理了理思路后发现要使代码通用性强一点,其实可以总结为几条规则。

当目前的字符为以下情况时:

  1. 数字字符:继续搜索。
  2. 小数点:
    1. 不可为第一位或者最后一位
    2. 不可出现在e/E后面
    3. 至多只可出现一次
  3. + / -
    1. 只可出现在第一位或者 e/E 后面
  4. e / E
    1. 不可为第一位或者最后一位
    2. 至多只可出现一次

总结来说有一个技巧,当出现了 e/E后,可以重新更新新视角意义上的数字第一位,因为其后面的字符可以定义为一个新的数字,只不过不可再出现 e/E 或者 小数点。

 

AC 代码:

# -*- coding:utf-8 -*-

class Solution:
    # s字符串
    def isNumeric(self, s):
        num_end_pos = len(s) - 1
        num_start_pos = 0
        e_mark = False
        dot_mark = False

        for i in range(num_end_pos+1):
            num = s[i]
            if num in '+-':
                if i > num_start_pos: return False
            elif num.isdigit(): continue
            elif num in '.':
                if not num_start_pos < i < num_end_pos or e_mark or dot_mark: return False
                else: dot_mark = True
            elif num in 'eE':
                if not num_start_pos < i < num_end_pos or e_mark: return False
                else:
                    e_mark = True
                    num_start_pos = i + 1
            else:
                return False
        return True

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值