java
public class Solution {
public int StrToInt(String str) {
if(str.equals("") || str == null){
return 0;
}
int sum = 0; // 返回结果
boolean flag = true; // 正负数标志位
char first = str.charAt(0); // 第一位
if( Character.isDigit(first) ){
sum += first - '0';
}else if( first == '-' ){
flag = false;
}else if( first != '+' ){
return 0;
}
for(int i=1; i<str.length(); i++){
char temp = str.charAt(i); //当前char
int tempInt;
if( Character.isDigit(temp) ){ //判断是否是数字
tempInt = temp - '0';// 取出当前char的int值
}else{
return 0;
}
// 溢出判断start ps:最大(int) 2^31-1 = 2,147,483,647 最小(int) -2^31 = -2,147,483,648
// 判断此时sum大于2,147,483,64时则必然溢出 直接返回0
if(sum > 214748364){
return 0;
}
// 正数判断最末位是否大于7 负数判断是否大于8
if(flag){
// 判断此时sum等于2,147,483,64时判断下一位如果大于7则溢出 直接返回0
if(sum == 214748364 && tempInt > 7){
return 0;
}
}else{
// 判断此时sum等于2,147,483,64时判断下一位如果大于7则溢出 直接返回0
if(sum == 214748364 && tempInt > 8){
return 0;
}
}// 溢出判断end
sum = sum*10 + tempInt;
}
return flag ? sum : -sum;
}
}