整理思路:这个题目,我是用非常复杂的思路做的。读懂题目后,根据具体情况分别考虑。
public class num_13 {
public static void main(String[] args) {
// String str = "20000000000000000000";
String str = " -42";
System.out.println(myAtoi(str));
}
public static int myAtoi(String str) {
str = str.trim();
if(str.isEmpty())
return 0;
char c_start = str.charAt(0);
String return_s = "";
if(c_start=='-') {
return_s = "-";
int i = 1;
while(i<str.length()) {
char c = str.charAt(i);
if(c>='0'&&c<='9') {
return_s += c;
i++;
}
else {
break;
}
}
}
else if(c_start=='+') {
return_s = "+";
int i = 1;
while(i<str.length()) {
char c = str.charAt(i);
if(c>='0'&&c<='9') {
return_s += c;
i++;
}
else {
break;
}
}
}
else if(c_start>='0'&&c_start<='9') {
int i = 0;
while(i<str.length()) {
char c = str.charAt(i);
if(c>='0'&&c<='9') {
return_s += c;
i++;
}
else
break;
}
}
else {
return 0;
}
if(return_s.equals("-")||return_s.equals("+"))
return 0;
System.out.println(return_s);
if(Double.parseDouble(return_s)>Integer.MAX_VALUE) {
return Integer.MAX_VALUE;
}
else if(Double.parseDouble(return_s)<Integer.MIN_VALUE) {
return Integer.MIN_VALUE;
}
else {
return Integer.parseInt(return_s);
}
}
}
后来找了下大神的博客,将具体的情况罗列如上。