将字符串转换成整数(atoi的实现)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了将字符串转换成整数(atoi的实现)相关的知识,希望对你有一定的参考价值。

思路:
1.‘+’,‘-’问题
2.NULL,‘\0’问题
3.其他字符问题,包括空格、tab
4.越界溢出问题
5.数字前面几位是0

#include<iostream>
using namespace std;
#include<stdlib.h>

enum Status{ KValid = 0, KInvalid }; //KVlid-合法 KInvalid-非法
int g_nStatus = KValid;  //在最后得到结果时,判断是合法的0,还是非法的非0

int StrToInt(const char* str)
{
	long long StrToIntCore(const char *digit, bool minus);
	g_nStatus = KInvalid;
	long long num = 0;

	if (str != NULL&&*str != ‘\0‘)//判空,‘\0‘
	{
		bool minus = false; //符号 默认为负

		if (*str == ‘+‘)
		{
			str++;
		}
		else if (*str == ‘-‘)
		{
			str++;
			minus = true;
		}

		if (*str != ‘\0‘)
		{
			num = StrToIntCore(str, minus);
		}
	}

	return (int)num;
}

long long StrToIntCore(const char *digit, bool minus)
{
	long long num = 0;
	while (*digit != ‘\0‘)
	{
		if (isdigit(*digit)) //while(*digit >= ‘0‘&&*digit <= ‘9‘)
		{
			int flag = minus ? -1 : 1;
			num = num * 10 + flag*(*digit - ‘0‘);

			if ((!minus&&num > 0x7fffffff) || (minus&&num < (signed int)0x80000000))
			{
				num = 0;
				break;
			}

			digit++;
		}
		else
		{
			num++;
			break;
		}
	}

	if (*digit == ‘\0‘)
	{
		g_nStatus = KValid;
	}

	return num;
}

int main()
{
	char str[] = "-12345";
	char str1[] = "-012345";
	char str2[] = "012345";
	char str3[] = "--12345";

	cout << StrToInt(str) << endl;
	cout << g_nStatus << endl;
	cout << StrToInt(str1) << endl;
	cout << g_nStatus << endl;
	cout << StrToInt(str2) << endl;
	cout << g_nStatus << endl;
	cout << StrToInt(str3) << endl;
	cout << g_nStatus << endl;

	system("pause");
	return 0;
}

技术分享

以上是关于将字符串转换成整数(atoi的实现)的主要内容,如果未能解决你的问题,请参考以下文章

字符串转换整数 (atoi) C++实现 java实现 leetcode系列

字符串转换整数 (atoi)

题目地址(8. 字符串转换整数 (atoi))

2021-09-12:请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。函数 myAtoi(string(

8. 字符串转换整数 (atoi)

LeetCode 8. 字符串转换整数 (atoi)