思路:
1.‘+’,‘-’問(wèn)題
2.NULL,‘\0’問(wèn)題
3.其他字符問(wèn)題,包括空格、tab
4.越界溢出問(wèn)題
5.數(shù)字前面幾位是0
#includeusing namespace std; #include enum Status{ KValid = 0, KInvalid }; //KVlid-合法 KInvalid-非法 int g_nStatus = KValid; //在最后得到結(jié)果時(shí),判斷是合法的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; //符號(hào) 默認(rèn)為負(fù) 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; }
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。