题目描述
将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0
输入描述:
输入一个字符串,包括数字字母符号,可以为空
输出描述:
如果是合法的数值表达则返回该数字,否则返回0
示例1
输入
+2147483647
1a33
输出
2147483647
0
public class Solution {
public int StrToInt(String str) {
int len=str.length();
if(len==0) return 0;
char ch=str.charAt(0);
int flag=1;
if(ch=='-') flag=-1;
if(ch!='+'&&ch!='-'&&(ch<'0'||ch>'9')) return 0;
int pos=(ch>='0'&&ch<='9')?0:1;
int ans=0;
int mx=Integer.MAX_VALUE;
int mn=Integer.MIN_VALUE;
while(pos<len){
ch=str.charAt(pos);
if(ch>='0'&&ch<='9'){
if(flag==1&&ans<=(mx-(ch-'0'))/10)
ans=ans*10+(ch-'0');
else if(flag==-1&&ans>=(mn+(ch-'0'))/10){
ans=ans*10-(ch-'0');
}
else{
return 0;
}
}
else{
return 0;
}
pos++;
}
return ans;
}
}