目录
- 一、什么是atoi函数
- 二、模拟atoi
一、什么是atoi函数
atoi函数是将字符串转换成整数。
int atoi (const char * str);
该函数的返回值为int类型的整数,转换后的值不可超出int可表示的范围。
注意:
1、该函数首先会丢弃尽可能多的空白字符,直到找到第一个非空白字符,然后,从这个字符开始,取一个可选的初识加号或者减号,后跟尽可能多的十进制数字,并将他们返回一个int类型的数值。
2、若该字符串是在整数的字符后包含其他字符,则这些字符将会被忽略,返回其他字符之前的整数,并且不会对该函数造成任何影响。
3、若该字符串中第一个非空字符序列表示有效的整数,或是一个空指针,或只包含空白字符,则不执行任何转换,并且返回零。
举个例子:
#include #include int main(){int ret = atoi("-123");printf("%d\n", ret);}
二、模拟atoi
在模拟atoi函数之前,我们应该考虑以下几种情况
情况一、传一个空字符串
my_atoi(“”);
情况二、传一个空指针
my_atoi(“NULL”);
情况三、传一个非常大的数字
my_atoi(“111111111111111111111111111111111”);
情况四、传一个非常大的负数
my_atoi(“-111111111111111111111111111111111”);
情况五、传一个整数加字母的字符串
my_atoi(“123asd”);
情况六、传一个空格加整数的字符串
my_atoi(“ 123”);
情况七、传一个负数的字符串
my_atoi(“-123”);
以上几种情况那些是非法的,那些又是合法的呢?
下面我们来用代码实现:
#include #include #include enum Status{VALID,INVALID};enum Status status = INVALID;int my_atoi(const char* str){if (str == NULL){return 0;}if (*str == '\0'){return 0;}//k=空白字符while (isspace(*str)){str++;}int flag = 1;if (*str == '+'){flag = 1;str++;}else if (*str == '-'){flag = -1;str++;}//处理数字字符long long ret = 0;while (isdigit(*str)){ret = ret * 10 + (*str - '0') * flag;if (ret<INT_MIN || ret>INT_MAX){return 0;}str++;}if (*str == '\0'){status = VALID;return (int)ret;}else{return (int)ret;}}int main(){int ret = my_atoi("-123");if (status == VALID)printf("合法转换:%d\n", ret);elseprintf("非法转换:%d\n", ret);return 0;}
经过测试:
(1)、情况一、二、三、四、五是非法的
情况一、二、三、四结果如下:
情况五的结果如下:
(2)、情况六、七是合法的
情况六的结果如下:
情况七的结果如下: