LeetCode:atoi函數 被折騰慘了

主要是情況太多了。。。。
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;
	}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章