#剑指offer#表示数值的字符串:弄清数值规则即可

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

# -*- coding:utf-8 -*-
class Solution:
    # s字符串
    def isNumeric(self, s):
        # write code here
        num_str = 0
        num_dec = 0
        num_flag = 0
        ls = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9']
        for i in range(len(s)):
            if s[i] == 'E': s = s[:i] + 'e' + s[i + 1:]
            if s[i] == '-': s = s[:i] + '+' + s[i + 1:]
            if s[i] == 'e':
                num_str += 1
            elif s[i] == '.':
                num_dec += 1
            elif s[i] == '+':
                num_flag += 1
            elif s[i] not in ls:  # 不能有规则以外的字符
                return False

        if s[-1] not in ls:  # 最后一位必须是数字
            return False
        if num_dec >= 2 or num_str >= 2:  # 不能两个小数点&不能两个e
            return False
        if num_dec == 1 and num_str == 1:  # e后不能有小数点
            if s.index('.') > s.index('e'):
                return False
        if num_flag == 1:  # 一个正号必须在第一位或者e后面
            if s[0] != '+':
                if s[s.index('+') - 1] != 'e':
                    return False
        if num_flag == 2:  # 两个正负号,第一个必须在首位,第二个必须紧跟‘e'
            if s[0] != '+':
                return False
            t=s[1:]
            if t[t.index('+') - 1] != 'e':
                return False
        return True

你可能感兴趣的:(数据结构)