C语言进阶习题【4】——模拟实现atoi

1. 题目描述

模拟实现atoi,atoi - C++ Reference (cplusplus.com)
库函数:< cstdlib >
在这里插入图片描述
将字符串转换为整数
解析C字符串str,将其内容解释为一个整数,返回为int类型的值。
该函数首先根据需要丢弃任意数量的空白字符(如isspace),直到找到第一个非空白字符。然后,从此字符开始采用可选的首字母加号或减号,后跟尽可能多的 base-10 数字,并将它们解释为数值。
字符串可以在形成整数的字符之后包含其他字符,这些字符被忽略,对该函数的行为没有影响。如果 str 中第一个非空白字符序列不是一个有效的整数,或者由于 str 为空或只包含空白字符而没有这样的序列,则不执行转换并返回0。

2. 思路

解决下面问题

  1. 空指针问题
  2. 空字符串问题
  3. 非数字字符
  4. 空白字符等,逗号字符
  5. 正负号

3.代码实现

#include<stdio.h>
#include <ctype.h>//atoi()
#include<assert.h>//assert()
#include<stdlib.h>//INT_MAX INT_MIN
enum state
{
	VALID,
	INVALID
}state = INVALID;//先一开始设置成非法

int* my_atoi(const char*str)
{
	assert(str);
	if (str == '\0')
	{
         //发现这样返回无论怎样都不合适,所以我们设置一个变量
		//判断当前返回值是否有效,合法还是非法
		//使用枚举
		return 0;
	}
	//跳过空白字符
	while (isspace(*str))
	{
		str++;//如果是空白字符,就跳过去了
	}
	//
	int flag = 1;//辨别是正数,还是负数
	if (*str == '+')
	{
		str++;
	}
	else if (*str == '-')
	{
		str++;
		flag = -1;
	}
	long long ret = 0;
	while (*str)
	{
		if(isdigit(*str))
		{
			ret = ret * 10 + flag * (*str - '0');
			if (ret > INT_MAX)//说明越界了
				//但是,如果存到n里面去,是肯定不会越界的,因为会发生截断
				//所以,设置成long long是最好的
			{
				return INT_MAX;
			}
			else if (ret < INT_MIN)
			{
				return INT_MIN;
			}
		}
		else
		{
			return (int)ret;
		}
		str++;
	}
	state = VALID;
	return (int)ret;
}


int main()
{
	int ret = my_atoi("1234123344adf1");
	
	if (state == 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、付费专栏及课程。

余额充值