题目
实现 atoi,将字符串转为整数。
提示: 仔细考虑所有输入情况。如果你想挑战自己,请不要看下面并自己考虑所有可能的输入情况。
说明: 这题解释的比较模糊(即没有指定输入格式)。你得事先汇集所有的输入情况。
atoi的要求:
这个函数需要丢弃之前的空白字符,直到找到第一个非空白字符。之后从这个字符开始,选取一个可选的正号或负号后面跟随尽可能多的数字,并将其解释为数字的值。
字符串可以在形成整数的字符后包括多余的字符,将这些字符忽略,这些字符对于函数的行为没有影响。
如果字符串中的第一个非空白的字符不是有效的整数,或者没有这样的序列存在,字符串为空或者只包含空白字符则不进行转换。
如果不能执行有效的转换,则返回0。如果正确的值超过的可表示的范围,则返回INT_MAX(2147483647)或INT_MIN(-2147483648)。
分析
- 题目要求第一个非空字符开始算必须是个整数
- 注意使用 long 来判定整数是否越界
- 不要使用 Math.pow(2, 31) 因为返回的 doble 类型数据转化为 int 后失真
解题
class Solution {
public int myAtoi(String str) {
str = str.trim();
if (str.length() == 0 || str.charAt(0) != '+' && str.charAt(0) != '-' && !isNum(str.charAt(0))) {
return 0;
}
int flag = 1;
long data = 0;
// Init the loop param.
int i = 0;
int len = str.length();
// Positive or negative num.
if (str.charAt(i) == '+' || str.charAt(i) == '-') {
flag = str.charAt(i) == '+' ? 1 : -1;
i++;
}
// Find the data.
while(i<len && isNum(str.charAt(i))) {
data = data*10 + (str.charAt(i) - '0');
if (flag*data < Integer.MIN_VALUE) {
return Integer.MIN_VALUE;
}
if (flag*data > Integer.MAX_VALUE) {
return Integer.MAX_VALUE;
}
i++;
}
return flag*(int)data;
}
public boolean isNum(char c) {
if ('0' <= c && c <= '9') {
return true;
}
return false;
}
}
启示
- 注意 char 类型的比较,比较字符而不是数字,’0’ 转化为 int 是 47
- 当 char 与数字进行比较时,可以用 c - ‘0’
- 注意输入为空或者单个元素时的情况
- 不要使用 Math.pow(2, 31) 因为返回的 doble 类型数据转化为 int 后失真