一、什么是atoi函数
atoi函数是将字符串转换成整数。
int atoi (const char * str);
该函数的返回值为int类型的整数,转换后的值不可超出int可表示的范围。
注意:
1、该函数首先会丢弃尽可能多的空白字符,直到找到第一个非空白字符,然后,从这个字符开始,取一个可选的初识加号或者减号,后跟尽可能多的十进制数字,并将他们返回一个int类型的数值。 2、若该字符串是在整数的字符后包含其他字符,则这些字符将会被忽略,返回其他字符之前的整数,并且不会对该函数造成任何影响。 3、若该字符串中第一个非空字符序列表示有效的整数,或是一个空指针,或只包含空白字符,则不执行任何转换,并且返回零。
举个例子:
#include <stdio.h>
#include <stdlib.h>
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 <stdio.h>
#include <ctype.h>
#include <limits.h>
enum Status
{
VALID,
INVALID
};
enum Status status = INVALID;
int my_atoi(const char* str)
{
if (str == NULL)
{
return 0;
}
if (*str == '\0')
{
return 0;
}
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);
else
printf("非法转换:%d\n", ret);
return 0;
}
经过测试: (1)、情况一、二、三、四、五是非法的 情况一、二、三、四结果如下: 情况五的结果如下: (2)、情况六、七是合法的 情况六的结果如下: 情况七的结果如下:
|