一道看似很简单的题,其实需要考虑很多情况。
1)需检测输入字符串的有效性
2)需跳过字符串前面的空格字符
3)需检测数字的正负性
4)需判断数字是否溢出
代码如下:
int My_atoi(char *str)
{
assert(str != NULL);
int overFlag = 0;
if (str == "")
{
return 0;
}
char *inputStr = str;
while (isspace((int)*inputStr))
{
inputStr++;
} //跳过前面的空格换行等空格字符
int num = 0;
char sign = 0;
if (*inputStr == '\0')
{
return 0;
}
else
{
if (*inputStr == '-' || *inputStr == '+')
{
sign = *inputStr++; //得到符号位
}
while (isdigit((int)*inputStr))
{
num = num * 10 + *inputStr - '0';
if (num < 0)
{
overFlag = 1;
break;
} //判断是否溢出
inputStr++;
}
}
if (sign == '-')
{
if (overFlag)
{
return INT_MIN;
}
return -num;
}
else
{
if (overFlag)
{
return INT_MAX;
}
return num;
} //判断符号位以及是否溢出整数范围
}