把字符串转换成整数
题目描述
将一个字符串转换成一个整数(实现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)