likes
comments
collection
share

字符串转换整数(atoi)

作者站长头像
站长
· 阅读数 0

请你来实现一个 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

思路

  1. 首先考虑是否是NaN(也就是在数字出现之前出现英文的时候是NaN) 出现的时候就return 0
  2. 其次在判断是否是'+' '-'(也就是在数字出现之前是'+'还是减 '-'
  3. 根据'+' '-' 判断是否大于
 Math.pow(2, 31) - 1) //大于的话就 return  Math.pow(2, 31) - 1
  1. 根据'+' '-' 判断是否小于
 Math.pow(2, 31) //小于的话就 return  Math.pow(2, 31)
  1. 0 <= s.length <= 200
  2. 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的用法 以及理解

Math 是数学函数,但又属于对象数据类型 typeof Math => ‘object’ console.dir(Math) 查看Math的所有函数方法。 Math.pow()获取一个值的多少次幂

parseInt的用法