剑指offer(49)把字符串转化为整数

public class Solution {
    public int StrToInt(String str) {
        if(str == null || str.equals("") || str.length() == 0){
            return 0;
        }
        char[] ch = str.toCharArray();
        if(!isValid(ch)){
            return 0;
        }
        int symbol = ch[0] == '-'? 1 : 0;
        int sum = 0;
        for(int i = symbol;i < ch.length;i++){
            if(ch[i] == '+'){
                continue;//如果第一位为正则跳出这一层的循环继续下一位
            }
            sum = sum * 10 + ch[i] - 48;//char字符想变成int。则需要ASCⅡ码转化
        }
       return symbol == 0 ? sum : sum * -1;//第一位为负号的情况要考虑到
        
    }
     public boolean isValid(char[] ch){//不合法情况封装成一个方法。一共由数字 字母 符号组成  那就从这方面入手
            for(int i = 1;i < ch.length;i++){//除第一位以外含有不是数字的
               if(ch[i] < '0' || ch[i] > '9'){
                   return false;
               }
            }
            if((ch[0] == '-' || ch[0] == '+') && ch.length == 1){//只有符号
                return false;
            }
            if(ch[0] == 0 && ch.length > 1){//第一位为0
                return false;
            }
            return true;
        }
}

猜你喜欢

转载自blog.csdn.net/qq_34403001/article/details/89307301