题目描述
将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0。
输入描述:
输入一个字符串,包括数字字母符号,可以为空
输出描述:
如果是合法的数值表达则返回该数字,否则返回0
示例1
输入
复制
+2147483647 1a33
输出
复制
2147483647 0
解题思路:
正数的最大值2147483647,负数的最小值-2147483648,正数直接转负数会出现越界问题
public class Solution {
public int StrToInt(String str) {
int len=str.length();
if(len<1)return 0;
int res=0;
boolean flag=true;
int i=0;
int j=0;
if(str.charAt(i)=='+'){
i++;
j++;
}else if(str.charAt(i)=='-'){
flag=false;
i++;
j++;
}else if(judStr(str.charAt(i))==false){
return 0;
}
for(;i<str.length();i++){
if(judStr(str.charAt(i))==false)return 0;
else {
if(j==0){
res+=Math.pow(10,len-j-i-1)*(str.charAt(i)-'0');
}else if(flag==true){
res+=Math.pow(10,len-j-i)*(str.charAt(i)-'0');
}else if(flag==false){
res+=-Math.pow(10,len-j-i)*(str.charAt(i)-'0');
}
}
}
//正数的最大值2147483647,负数的最小值-2147483648,正数直接转负数会出现越界问题
return res;
//不能直接在最后判断是正负,加符号 return flag==true?res:(-res);
}
boolean judStr(char ch){
if(ch<'0' ||ch>'9')return false;
return true;
}
}