字符串转换整数(atoi)
请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。
-
读入字符串并丢弃无用的前导空格
-
检查下一个字符(假设还未到字符末尾)为正还是负号,读取该字符(如果有)。 确定最终结果是负数还是 正数。 如果两者都不存在,则假定结果为正。
-
读入下一个字符,直到到达下一个非数字字符或到达输入的结尾。字符串的其余部分将被忽略。
-
将前面步骤读入的这些数字转换为整数(即,"123" -> 123, "0032" -> 32)。如果没有读入数字,则整 数为 0 。必要时更改符号(从步骤 2 开始)。
-
如果整数数超过 32 位有符号整数范围 [−231, 231 − 1] ,需要截断这个整数,使其保持在这个范围内。具体来说,小于 −231 的整数应该被固定为 −231 ,大于 231 − 1 的整数应该被固定为 231 − 1 。
-
返回整数作为最终结果。 注意:
-
本题中的空白字符只包括空格字符
' '
。 -
除前导空格或数字后的其余字符串外,请勿忽略 任何其他字符。
基本题目有
输入: s = "42"
输出: 42
输入: s = " -42"
输出: -42
输入: s = "4193 with words"
输出: 4193
输入: s = "words and 987"
输出: 0
思路
- 首先考虑是否是NaN(也就是在数字出现之前出现英文的时候是NaN) 出现的时候就return 0
- 其次在判断是否是
'+'
'-'
(也就是在数字出现之前是'+'
还是减'-'
) - 根据
'+'
'-'
判断是否大于
Math.pow(2, 31) - 1) //大于的话就 return Math.pow(2, 31) - 1
- 根据
'+'
'-'
判断是否小于
Math.pow(2, 31) //小于的话就 return Math.pow(2, 31)
0 <= s.length <= 200
s
由英文字母(大写和小写)、数字(0-9
)、' '
、'+'
、'-'
和'.'
组成
代码实现
var myAtoi = function (s) {
let a = parseInt(s, 10);
if (isNaN(a)) {
return 0;
} else {
if (a >= Math.pow(2, 31) - 1) {
return Math.pow(2, 31) - 1;
}
if (a <= Math.pow(-2, 31)) {
return Math.pow(-2, 31);
}
}
return a;
};
这里边主要运用了 parseInt 判断的 是否是正整数 还有Math的运用
Math
是数学函数,但又属于对象数据类型 typeof Math
=> ‘object’
console.dir(Math)
查看Math的所有函数方法。
Math.pow()获取一个值的多少次幂
转载自:https://juejin.cn/post/6988443609087344654