剑指offer-表示数值的字符串

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

思路:要综合考虑到各种情况

class Solution {
    public boolean isNumber(String s) {
        if (s == null || s.length() == 0){
            return false;
        }
        boolean isNum = false, isDot = false, ise = false;
        char[] str = s.trim().toCharArray();//删除字符串头尾空格,转为字符型数组
        for (int i = 0; i < str.length; i++){
            if (str[i] >= '0' && str[i] <= '9') isNum = true;//判断当前字符是否为0~9数位
            else if (str[i] == '.'){//遇到小数点
                if (isDot || ise){//小数点前可以没有整数,但不能有重复小数点或e/E
                    return false;
                }
                isDot = true;
            }
            else if (str[i] == 'e' || str[i] == 'E'){//遇到e或者E
                if (! isNum || ise){//e/E前必须有整数,且前面不能有e/E
                    return false;
                }
                ise = true;
                isNum = false;//重置isNum,因为e/E后必须接上整数,防止出现123e、123e+
            }
            else if (str[i] == '-' || str[i] == '+'){//遇到正负号
                if (i != 0 && str[i - 1] != 'e' && str[i - 1] != 'E'){//正负号只能出现在第一位或出现在e/E后一个位置
                    return false;
                }
            }
            else return false;//其余情况均不成立
        }
        return isNum;
    }
}
上一篇:基于Basys2开发板的ISE设计


下一篇:使用ISE软件制作网表文件