手写常用算法代码2 - 字符串转整数

思路分析 :

首先判断字符串是否为空,返回0
考虑前面的是否是空格,使用trim()去掉,然后判断长度是否为0,是的话,返回0
判断第一个字符是不是+和-,设置变量sign记录
循环取得字符串的数字,考虑字符串中有非数字,遇到就退出,保留前面的数字
考虑溢出的情况,溢出返回Integer的最大值或最小值

int myAutoNumber(String str){
        //首先判断空值
        if(str == null){
            return 0;
        }
        //去掉空格的情况
        str = str.trim();
        if(str.length() == 0)
            return 0;
        //正负数标志
        int sign = 1;
        int index = 0;
        if(str.charAt(index) == '+')
            index ++;
        else if(str.charAt(index) == '-'){
            index ++;
            sign = -1;
        }
        //取得数字部分,遇到溢出和非数字退出
        long number = 0;
        for(; index < str.length();index++){
            if(str.charAt(index) < '0' && str.charAt(index) > '9'){
                break;
            }
            number = number * 10 + (str.charAt(index) - '0');        // 关键计算模式
            if(number >= Integer.MAX_VALUE)
                break;
        }
        if(number * sign <= Integer.MIN_VALUE)
            return Integer.MIN_VALUE;
        if(number * sign >= Integer.MAX_VALUE)
            return Integer.MAX_VALUE;
        return (int) number * sign;
    }

你可能感兴趣的:(手写常用算法代码2 - 字符串转整数)