public int atoi(String str) {
int num = 0;
int sign = 1;
int j = 0;
while (j < str.length()) {
if (str.startsWith(" ")) {
str = str.substring(1);
j++;
} else
break;
}
if (str.startsWith("+"))
str = str.substring(1);
if (str.startsWith("-")) {
str = str.substring(1);
sign = -1;
}
int n = str.length();
for (int i = 0; i < n; i++) {
if (str.charAt(i) < '0' || str.charAt(i) > '9')
break;
int x = str.charAt(i) - '0';
if (num > Integer.MAX_VALUE / 10
|| (num == Integer.MAX_VALUE / 10 && x > Integer.MAX_VALUE % 10)) {
return sign == -1 ? Integer.MIN_VALUE : Integer.MAX_VALUE;
}
num = num * 10 + x;
}
return num * sign;
}
LeetCode:atoi函數 被折騰慘了
主要是情況太多了。。。。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.