把字符串转换成整数

第四十八题:把字符串转换成整数


题目描述

将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0。
输入描述:输入一个字符串,包括数字字母符号,可以为空输出描述:
如果是合法的数值表达则返回该数字,否则返回0

输入描述:
输入一个字符串,包括数字字母符号,可以为空
输出描述:
如果是合法的数值表达则返回该数字,否则返回0
示例1

输入
+2147483647
1a33

输出
2147483647
0


思路

实际上我们可以翻看一下JDK的源码,会发现Integer.valueOf()的实现是调用parseInt(str,radix)方法
str:实际传入的字符串参数
radix:转换的进制数
仔细想想让我们自己实现valueOf函数,第一我们要考虑输入字符串是否是“合格”的。
第二,我们知道该字符串的“正负”。
第三,将字符串转换成数字。

具体实现如下图所示

把字符串转换成整数


具体实现代码如下
public class Solution {
    public int StrToInt(String str) {
        // 代码的鲁棒性
        if(str == null || str.length() == 0){
            return 0;
        }
        // 判断正负
        boolean negative = str.charAt(0) == '-';
        // result
        int sum = 0;
        for(int i = 0; i < str.length();i++){
            char c = str.charAt(i);
            // 如果第一位为+或-   说明是合格的,继续进行
            if(i == 0 && (c == '-' || c == '+')){
                continue;
            }
            // 说明该字符串出现了不合格的字符,直接返回 0
            if(c < '0' || c > '9'){
                return 0;
            }
            // 字符串转换成数字的核心  
            sum = sum * 10 +(c - '0');
        }
        return negative ? -sum : sum;
    }
}

NowCoder(Online Coding, Please Click)