请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。
函数 myAtoi(string s) 的算法如下:
丢弃前导空格
检查下一个字符(假设还未到字符末尾)为正还是负号,读取该字符(如果有)。 确定最终结果是负数还是正数。 如果两者都不存在,则假定结果为正。
读入下一个字符,直到到达下一个非数字字符或到达输入的结尾。字符串的其余部分将被忽略。
将前面步骤读入的这些数字转换为整数。如果没有读入数字,则整数为 0 。必要时更改符号(从步骤 2 开始)。
小于 −2^31 的整数应该被固定为 −2^31 ,大于 2^31 − 1 的整数应该被固定为 2^31 − 1 。
示例 1:
输入:s = “8”
输出:8
示例 2:
输入:s = " -8"
输出:-8
示例 3:
输入:s = “8 with words”
输出:8
示例 4:
输入:s = “words and 8”
输出:0
示例 5:
输入:s = “-8147483648”
输出:-2147483648
提示:
0 <= s.length <= 200
s 由英文字母(大写和小写)、数字(0-9)、’ ‘、’+’、’-’ 和 ‘.’ 组成
class Solution {
public int myAtoi(String s) {
//删除前导空格
s = s.trim();
//整数默认为 0
long num = 0;
//只有一个数字
if(1==s.length() && Character.isDigit(s.charAt(0)))
num = s.charAt(0) - 48;
//符号加数字
if(s.length() > 1) {
//数字开始的下标
int numIndex = 0;
if('+'==s.charAt(0) || '-'==s.charAt(0))
numIndex = 1;
//字符串转换整数
while(numIndex<s.length() && Character.isDigit(s.charAt(numIndex))) {
//不转换整数开头的 0
num = num * 10 + (s.charAt(numIndex++) - 48);
if('-'!=s.charAt(0) && num>=Integer.MAX_VALUE) {
num = Integer.MAX_VALUE;
break;
}
if('-'==s.charAt(0) && -num<=Integer.MIN_VALUE) {
num = -Integer.MIN_VALUE;
break;
}
}
//添加负号
if('-' == s.charAt(0))
num *= -1;
}
return (int)num;
}
}