问题描述:
自己实现一个MyAtoi函数,要和C语言库函数的atoi函数完成同样的功能。
问题分析:
首先我们要了解一下atoi函数它到底做了什么事情
(1) 函数原型
int atoi (const char * str);
(2) 函数说明
atoi函数会扫描参数 str 字符串,跳过前面的空白字符(下面会解释空白字符),直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时(‘\0’)才结束转换,并将结果返回。
PS:空白字符包括:空格(’ ‘)、定位字符(’ \t ‘)、CR(’ \r ‘)、换行(’ \n ‘)、垂直定位字符(’ \v ‘)或翻页(’ \f ‘)
(3) 返回值
返回转换后的整型数;如果 str 不能转换成 int 或者 str 为空字符串,那么将返回 0。
根据以上的描述,我们可以来实现自己的代码了
参考代码:
#include <stdio.h>
#include <stdlib.h>
int MyIsSpace(char ch)
{
if (ch == ' ' || ch == '\t' || ch == '\n' || ch == '\f' || ch == '\v' || ch == '\r')
return 1;
return 0;
}
int MyIsDigit(char ch)
{
if (ch >= '0' && ch <= '9')
return 1;
return 0;
}
int MyAtoi(const char* pStr)
{
char sign;
int nValue = 0;
while (MyIsSpace(*pStr))//去掉空字符
pStr++;
sign = *pStr;
if (sign == '-' || sign == '+')
pStr++;
while (MyIsDigit(*pStr))
{
nValue = 10 * nValue + (*pStr - '0');
pStr++;
}
return sign == '-' ? -nValue : nValue;
}
int main()
{
char str[100];
gets_s(str, 100);
printf("MyAtoi = %d\n", MyAtoi(str));
printf("atoi = %d\n", atoi(str));
return 0;
}
运行结果: