剑指 Offer 20. 表示数值的字符串 09-02

题目

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

  • 很取巧的做法,利用Java自带的类型转换方法,抛出异常则非数字字符串,但同时也需要注意"7.8f或者7.8d"类似格式,按题目要求应该返回false
class Solution {
    public boolean isNumber(String s) {
        boolean result = true;
        try{
            Double.valueOf(s);
        }catch(Exception e){
            result = false;
        }
        
        if(result && (s.indexOf("f") != -1 || s.indexOf("F") != -1 || 
s.indexOf("d") != -1 || s.indexOf("D") != -1)){
                result = false;
        }

        return result;
    }
}
  • 题目本意应该是利用有限状态自动机解决,这个没学好,一会儿再看

你可能感兴趣的:(剑指 Offer 20. 表示数值的字符串 09-02)