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