原创

【剑指Offer】053——表示数值的字符串(字符串)

题目描述

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

解题思路

设置三个标志符分别记录“+/-”、“e/E”和“.”是否出现过。

  • 对于“+/-”: 正常来看它们第一次出现的话应该出现在字符串的第一个位置,如果它第一次出现在不是字符串首位,而且它的前面也不是“e/E”,那就不符合规则;如果是第二次出现,那么它就应该出现在“e/E”的后面,如果“+/-”的前面不是“e/E”,那也不符合规则。
  • 对于“e/E”: 如果它的后面不接任何数字,就不符合规则;如果出现多个“e/E”也不符合规则。
  • 对于“.”: 出现多个“.”是不符合规则的。还有“e/E”的字符串出现“.”也是不符合规则的。
    同时,要保证其他字符均为 0-9 之间的数字。

参考代码

public class Solution {
    public boolean isNumeric(char[] str) {
        int len = str.length;
        // 几种标记,正负标记/小数标记/E标记
        boolean sign = false, decimal = false, hasE = false;
        // 遍历查找
        for(int i = 0; i < len; i++){
            // 正负标记(-可在中间出现)
            if(str[i] == '+' || str[i] == '-'){
                // 中间第一次出现,但是出现之前的字符不是e/E
                if(!sign && i > 0 && str[i-1] != 'e' && str[i-1] != 'E')
                    return false;
                // 第二次出现,但是出现之前的字符不是e/E
                if(sign && str[i-1] != 'e' && str[i-1] != 'E')
                    return false;
                // 第一次出现
                sign = true;
            }else if(str[i] == 'e' || str[i] == 'E'){
                // 最后一次出现e/E
                if(i == len - 1)
                    return false;
                // 已经有过E了,不能再次出现
                if(hasE)
                    return false;
                hasE = true;
            }else if(str[i] == '.'){
                // 有E了就不能使用小数点了,或者已经有小数点了,不能再有小数点
                if(hasE || decimal)
                    return false;
                decimal = true;
            }else if(str[i] < '0' || str[i] > '9') // 最后,如果不是数字
                return false;
        }
        return true;
    }
}

Python

# -*- coding:utf-8 -*-
class Solution:
    # s字符串
    def isNumeric(self, s):
        # write code here
        s_len = len(s)
        sign, decimal, hasE = False, False, False
        for i in range(s_len):
            if s[i] == "+" or s[i] == "-":
                if not sign and i > 0 and s[i - 1] != 'e' and s[i-1] != 'E':
                    return False
                if sign and s[i - 1] != 'e' and s[i-1] != 'E':
                    return False
                sign = True
            elif s[i] == 'e' or s[i] == 'E':
                if i == s_len - 1:
                    return False
                if hasE:
                    return False
                hasE = True
            elif s[i] == '.':
                if hasE or decimal:
                    return False
                decimal = True
            elif s[i] > '9' or s[i] < '0':
                return False
        return True
正文到此结束
本文目录