字符串轉(zhuǎn)換整數(shù)需要注意下面四個(gè)問題备韧,尤其需要注意關(guān)于溢出的處理附较。
- 字符串是否為空
- 是否包含正負(fù)號
- 是否包含其它字符
- 是否溢出 int表示范圍為2147483647 ***
#include <iostream>
#include <string>
#define INF 0x7fffffff
using namespace std;
/*
1. 字符串是否為空
2. 是否包含正負(fù)號
3. 是否包含其它字符
4. 是否溢出 int表示范圍為2147483647 ***
*/
int strToInt(string str)
{
bool sign = true;
if(str.size() == 0)
return 0;
if(str[0] == '-')
sign = false;
int ans = 0;
for(int i = (sign?0:1); i < str.size(); ++i)
{
//if(str[i] < '0' || str[i] > '9')
//break;
if(isspace(str[i]))
continue;
if(isdigit(str[i]))
{
int v = str[i] - '0';
/*
//判斷是否溢出
if(sign && v > INF-ans*10) //需要注意ans*10可能已經(jīng)溢出檐涝,影響最終結(jié)果帝蒿,因此需判斷INF/10與ans的大小答渔,如果相等,還需判斷INF%10與字符v的大小
{
ans = INF;
break;
}
if(!sign && v > (unsigned)INF+1 -ans*10)
{
ans = -INF-1;
break;
}
*/
if(sign && (ans > INF/10 || (ans == INF/10 && v > INF%10)))
{
ans = INF;
break;
}
if(!sign && (ans > ((unsigned)INF+1)/10 || (ans == ((unsigned)INF+1)/10 && v > ((unsigned)INF+1)%10)))
{
ans = (unsigned)INF+1;
break;
}
ans = ans*10 + v;
}
}
return sign ? ans : -ans;
}
int main()
{
freopen("in.txt", "r", stdin);
string str;
while(getline(cin, str))
{
cout << strToInt(str) << endl;
}
return 0;
}