class Solution {
public:
int myAtoi(string str) {
int i = 0, sign = 1, n = str.size();
long long result = 0;
//while (str[i] == " ") //写错了 双引号表示的是字符串
while (str[i] == ' ')
{
i++;
}
//while (str[i] == '-' || str[i] == '+')
//{
if (str[i] == '-')
{
sign = -sign;
i++;
}
else if (str[i] == '+')
i++;
/* }*/
for (int j = i; j != n; j++)
{
if (str[j] >= '0' && str[j] <= '9')
result = result * 10 + (str[j] - '0');
else
{
if (result)
return result*sign;
else
return 0;
}
if (result > INT_MAX)
return sign == -1 ? INT_MIN : INT_MAX;
}
if (sign==-1)
return -result;
else
return result;
}
public:
int myAtoi(string str) {
int i = 0, sign = 1, n = str.size();
long long result = 0;
//while (str[i] == " ") //写错了 双引号表示的是字符串
while (str[i] == ' ')
{
i++;
}
//while (str[i] == '-' || str[i] == '+')
//{
if (str[i] == '-')
{
sign = -sign;
i++;
}
else if (str[i] == '+')
i++;
/* }*/
for (int j = i; j != n; j++)
{
if (str[j] >= '0' && str[j] <= '9')
result = result * 10 + (str[j] - '0');
else
{
if (result)
return result*sign;
else
return 0;
}
if (result > INT_MAX)
return sign == -1 ? INT_MIN : INT_MAX;
}
if (sign==-1)
return -result;
else
return result;
}
};
一开始题都没读懂,后来从网上看了看别人的,才知道只是转换string中的数字,不用考虑字母这些的转换(好像也不需要?)。
那这样就很好处理了,首先字符串中的空格要过滤掉,过滤的时候,空格要单引号(双引号是字符串)。在一个判断符号,之后就判断数字进行转换即可。
如果连续遇到正负号返回0。再加上判断是否超过INT_MAX。