题目描述
将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0。
输入描述:
输入一个字符串,包括数字字母符号,可以为空
输出描述:
如果是合法的数值表达则返回该数字,否则返回0
示例
输入: "42"
输出: 42
输入: " -42"
输出: -42
解释: 第一个非空白字符为 '-', 它是一个负号。
我们尽可能将负号与后面所有连续出现的数字组合起来,最后得到 -42 。
AC C++ Solution:
class Solution {
public:
int StrToInt(string str) {
int len = str.length();
int i = 0;
int num = 0, flag = 1;
while(str[i] == ' ')
i++;
if(str[i] == '-') {
i++;
flag = -1;
}
else if(str[i] == '+')
i++;
for( ; i < len; i++) {
if(str[i] < '0' || str[i] > '9')
return 0;
if(num > INT_MAX/10 || (num == INT_MAX/10 && str[i] - '0' > 7)) {
if(flag == 1)
return INT_MAX;
else
return INT_MIN;
}
num = num*10 + (str[i] - '0');
}
return num*flag;
}
};