题目描述
将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0
输入描述
输入一个字符串,包括数字字母符号,可以为空
输出描述
如果是合法的数值表达则返回该数字,否则返回0
示例1
输入
+2147483647
1a33
输出
2147483647
0
解题思路
- 各种异常的处理过程
class Solution {
public:
int StrToInt(string str) {
if(str.size() == 0){
return 0;
}
int i = 0;
while(str[i] == ' '){ // 判断前面的空值
i++;
}
int flag = 1;
if(str[i] == '-' || str[i] == '+'){ // 判断正负号
if(str[i] == '-'){
flag = -1;
}
i++;
}
if(str[i] == '0'){ // 开头有0的情况
return 0;
}
long long res = 0;
for(; i < str.size(); i++){
if(str[i] < '0' || str[i] > '9'){
return 0;
}
res = res * 10 + str[i] - '0';
if(res * flag > INT_MAX || res * flag < INT_MIN){ // 判断溢出
return 0;
}
}
return res * flag;
}
};
class Solution {
public:
int StrToInt(string str) {
int symbol = 0;
if(str.size() == 0){
return 0;
}
int k = 0, len = str.size();
while(k < len && str[k] == ' ') k++;
if(str[k] == '+'){
k++;
}else if(str[k] == '-'){
symbol = 1;
k++;
}
long long res = 0;
while(str[k] >= '0' && str[k] <= '9'){
res = res * 10 + (str[k] - '0');
k++;
}
if(str[k] != '\0'){
return 0;
}
if(symbol){
res = -res;
}
if(res > INT_MAX || res < INT_MIN){
return 0;
}
return (int)res;
}
};