1.1、题目1

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

1.2、解法

这题表示直接上大佬的题解把。。。。
代码太长了。有限状态自动机。
对状态机一无所知的我一脸懵

1.3、代码

class Solution {
    public boolean isNumber(String s) {
        Map[] states = {
            new HashMap<>() {{ put(' ', 0); put('s', 1); put('d', 2); put('.', 4); }}, // 0.
            new HashMap<>() {{ put('d', 2); put('.', 4); }},                           // 1.
            new HashMap<>() {{ put('d', 2); put('.', 3); put('e', 5); put(' ', 8); }}, // 2.
            new HashMap<>() {{ put('d', 3); put('e', 5); put(' ', 8); }},              // 3.
            new HashMap<>() {{ put('d', 3); }},                                        // 4.
            new HashMap<>() {{ put('s', 6); put('d', 7); }},                           // 5.
            new HashMap<>() {{ put('d', 7); }},                                        // 6.
            new HashMap<>() {{ put('d', 7); put(' ', 8); }},                           // 7.
            new HashMap<>() {{ put(' ', 8); }}                                         // 8.
        };
        int p = 0;
        char t;
        for(char c : s.toCharArray()) {
            if(c >= '0' && c <= '9') t = 'd';
            else if(c == '+' || c == '-') t = 's';
            else if(c == 'e' || c == 'E') t = 'e';
            else if(c == '.' || c == ' ') t = c;
            else t = '?';
            if(!states[p].containsKey(t)) return false;
            p = (int)states[p].get(t);
        }
        return p == 2 || p == 3 || p == 7 || p == 8;
    }
}



2.1、题目2

剑指 Offer 67. 把字符串转换成整数

2.2、解法

这题遍历字符串,判断首字母,从而不断赋值添加给res,这里有个小陷阱,就是要注意数的大小范围,超出范围则返回规定数的最大和最小值。

2.3、代码

class Solution {
    public int strToInt(String str) {
        int res = 0,sign = 1,bndry = Integer.MAX_VALUE / 10;;
        char []s = str.trim().toCharArray();
        int j = 1,len = s.length;
        if(len == 0 )return 0;
        if(s[0]=='-') sign=-1;
        else if(s[0]!='+') j=0;
        for(int i =j;i<len;i++){
            if(s[i]>'9' || s[i]<'0') break;
            if(res > bndry || res == bndry && s[i] > '7') return sign == 1 ? Integer.MAX_VALUE : Integer.MIN_VALUE;
            res=res*10+(s[i]-'0');

        }
        return sign*res;
    }

}