int atoi( const char *str ) {
int answer = 0, symbol = 1, i = 0, n = 0;
if( str == NULL ) {
return 0;
}
for( i = 0; str[i] != '\0' && str[i] == ' '; ++i ) {} // 跳过前导空格.
if( str[i] == '-' || str[i] == '+' ) { // 处理首个有效字符是符号位.
symbol = str[i++] != '-' ? 1 : -1;
}
for( ; str[i] != '\0' && isdigit( str[i] ); ) {
n = (str[i++] - '0') * symbol;
if( (answer > INT_MAX / 10) || (answer == INT_MAX / 10 && n > INT_MAX % 10) ) { // 上溢出.
return INT_MAX;
}
if( (answer < INT_MIN / 10) || (answer == INT_MIN / 10 && n < INT_MIN % 10) ) { // 下溢出.
return INT_MIN;
}
answer = answer * 10 + n;
}
return answer;
}