【模拟实现atoi】

本文介绍了C语言中将字符串转化为整数的atoi函数,包括其功能、工作原理及核心思想。文章详细阐述了如何处理字符串中的异常情况,并提供了代码实现的概述。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


什么是atoi函数

atoi函数是将字符串转化为数字字符。其形式如下:

int atoi (const char * str);

解析C-string的str,将其内容解释为整数,并返回int类型的值。该函数首先根据需要丢弃任意数量的空白字符,直到找到第一个非空白字符。然后,从这个字符开始,接受一个可选的初始加号或减号,后面跟着尽可能多的10进制数字,并将它们解释为数值。

这个字符串可以包含整数之后的其他字符,这些字符会被忽略,而且不会影响这个函数的行为。

如果str中的第一个非空白字符序列不是有效的整数,或者因为str为空或只包含空白字符而不存在此类序列,则不会执行转换并返回0。


一、核心思想

对于字符串转化为数字其实并不难,但是本题的核心在于考虑众多的异常情况,比如遇到如下情况该如何处理:

my_atoi(NULL)//异常
my_atoi("")//异常
my_atoi("    +123")//正常
my_atoi("-123")//正常
my_atoi("123abc")//异常
my_atoi("1111111111111111111111111")//异常
my_atoi("-1111111111111111111111111")//异常

二、代码的实现

# include <ctype.h>
# include<stdio.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;
	}

	//遇到空白字符跳过
	if (isspace(*str))
	{
		str++;
	}

	//判断正负号,并把信息留存
	int flag = 1;
	if (*str == '+')
	{
		flag = 1;
		str++;
	}
	else if (*str == '-')
	{
		flag = -1;
		str++;
	}

	long long ret = 0;  //防止字符串的数字过大,int类型存不下
	while (isdigit(*str)) //-123
	{
		ret = ret * 10 + (*str - '0');
		if (ret > _CRT_INT_MAX)
		{
			return 0;
		}

		str++;
	}
		ret *= flag;

		if (*str == '\0')
		{
			status = VALID;
			return (int)ret;
		}
		else
		{
			return 0;
		}


	
}


int main()
{

	int ret = my_atoi("12322");
	if (status == VALID)
		printf("合法的转换:%d\n", ret);
	else
		printf("非法的数据转换:%d\n", ret);
	return 0;
}

在这里插入图片描述


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值