剑指offer18

题目描述

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

解题思路分析

其实这道看着麻烦,其实不麻烦,我只要认真分析了,就必定能够解出来,咱们要对于每次可能碰到字符按状况分析就能够函数

  • 当出现的字符是E或e时,这个时候咱们须要直到,若是前面已经出现了E或e的话,那确定就不是数值了,还有就是当e或E出如今最后一个位置时也不是数值
  • 当出现的是+或-时,若是已经出现过+或-且前面一位也不是E或e的话,那确定不是数值,若是没有出现过+或-且目前出现位置不在第一个且前面一位也不是E或e的话,那也不是数值
  • 当出现的是.的话,若是已经出现了.或者已经出现了E或e的话,那确定不是数值
  • 当出现非0-9的其余字符时,也不是数值
    有上面四步的分析就很好写代码了

代码实现

public isNumeric(char[] str){
    if (str == null || str.length <= 0) {
        return false;
    }
    boolean hasE = false, demical = fasle, sign =false;
    int length = str.length;
    for (int i = 0; i < length; i++) {
        //出现E或e
        if (str[i] == 'E' || str[i] == 'e') {
            //已经出现过了,那就返回false
            if (hasE) {
                return false;
            }
            //或者在最后一个位置出现
            if (i == length - 1) {
                return false;
            }
            hasE = true;
        } else if (str[i] == '+' || str[i] == '-') {
            //已经出现过了+或-且前面一位不是E或e
            if (sign && (str[i - 1] != 'E' && str[i - 1] != 'e')) {
                return false;
            }
            //没有出现过+或-可是不是在第一位出现且前面一位不是E或e
            if (!sign && i > 0 && (str[i - 1] != 'E' && str[i - 1] != 'e')) {
                return false;
            }
            sign = true;
        } else if (str[i] == '.') {
            //若是出现过.或者出现了E或e
            if (hasE || demical) {
                return false;
            }
            demical = true;
        } else if (str[i] < '0' || str[i] > '9') {
            //出现其余字符
            return false;
        }
    }
    return true;
}
复制代码
相关文章
相关标签/搜索