class Solution {
public:
    int atoi(const char *str) {
        // 1. 处理空字符串
        // 2. 忽略前置空格
        // 3. 保存符号
        // 4. 处理非法输入
        // 5. 处理溢出
        int idx = 0, sign = 1, val = 0;
        // 1. 处理空字符串
        if(strlen(str) == 0) return 0;
        // 2. 忽略前置空格
        while(str[idx] == ' ') ++idx;
        // 3. 保存符号
        if(str[idx] == '-') {
            sign = -1;
            ++idx;
        }
        if(str[idx] == '+')
            ++idx;
        for(; idx < strlen(str); ++idx) {
            // 4. 处理非法输入
            if(str[idx] > '9' || str[idx] < '0')
                break;
            // 5. 处理溢出
            if(val > INT32_MAX / 10 || (val == INT32_MAX / 10 && INT32_MAX % 10 < str[idx] - '0')) {
                return sign == 1 ? INT32_MAX : INT32_MIN;
            }
            val = val * 10 + str[idx] - '0';
        }
        return val * sign;
    }
};