atoi函数:将字符串转换为相应的整型数。
isspace函数:检查是否为空格,跳格符(制表符或换行符),是则返回1,否则返回0。
isdigit函数:检查是否为数字(0~9)。是则返回1,否则返回0。
注意:字符串中间无空格,符号在最前方。
#include <ctype.h>
int atoi(char s[])
{
int i, n, sign;
for (i = 0;isspace(s[i]);i++)
;
sign = (s[i] == '-') ? -1 : 1;
if (s[i] == '+' || s[i] == '-')
i++;
for (n = 0; isdigit(s[i]);i++)
n = 10 * n + (s[i] - '0');
return sign * n;
}
atoi函数运行过程:
假设一个字符串为s[7] = -134(负号前方有三个空格)
1、先执行第一个for循环,跳过空白符,当i = 3时,跳出循环。
2、执行三元运算符。s[3] =’-’,所以sign = -1。
3、执行if语句,跳过符号,s[3] = ‘-’,所以i自加得4。
4、执行第二个for循环。
第一次循环n = 10 * n + (s[4] - ‘0’) = 100+(49-48)=1
第二次循环n = 10 * n + (s[5] - ‘0’) = 101+(51-48)=13
第三次循环n = 10 n + (s[6] - ‘0’) = 1013+(53-48)=134
然后跳出循环。
5、返回sign * n = (-1) * 134 = -134。