class Solution {
public:
int myAtoi(string str) {
int k = 0;
long number = 0;
while (str[k] == ' ') k++;
if (str.length() == 0) return 0;
if (str[k] != '+' && str[k] != '-' && str[k]<'0' && str[k]>'9')
return 0;
bool flag = true;
if (str[k] == '+') {
flag = true;
k++;
}
else if (str[k] == '-') {
flag = false;
k++;
}
while (1) {
if (str[k] >= '0'&&str[k] <= '9') {
number = number * 10 + str[k] - '0';
if (flag&&number >= INT_MAX) return INT_MAX;
else if ((!flag)&&(number > INT_MAX)) return INT_MIN;
}
else break;
k++;
}
if (number == 0) return number;
else {
if (flag) return (int)number;
else return -(int)number;
}
}
};