经典算法-字符串转化为整数

经典算法题-把字符串转化为整数值

思路分析

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

代码如下:

public class Solution {
    public static 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;
    }
}

你可能感兴趣的:(经典算法题)