8. 字符串转换整数 (atoi)

2020-03-19
字符串转换整数 (atoi)
请你来实现一个 atoi 函数,使其能将字符串转换成整数。 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。 当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组合起来,作为该整数的正负号;假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数。 该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响。 注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换。 在任何情况下,若函数不能进行有效的转换时,请返回 0。
示例:
输入: '42'
输出: 42
输入: '     -42'
输出: -42
解释: 第一个非空白字符为 '-', 它是一个负号。 我们尽可能将负号与后面所有连续出现的数字组合起来,最后得到 -42 。
输入: '4193 with words'
输出: 4193
解释: 转换截止于数字 '3' ,因为它的下一个字符不为数字。
输入: 'words and 987'
输出: 0
解释: 第一个非空字符是 'w', 但它不是数字或正、负号。 因此无法执行有效的转换。
输入: '-91283472332'
输出: -2147483648
解释: 数字 "-91283472332" 超过 32 位有符号整数范围。 因此返回 INT_MIN (−2^31) 。
题解:
思路1: 数学
先清除字符串两侧的空格,再通过空格将字符串拆成数组取第一项。
再将第一项中的字符串打散成数组
判断数组第一项是否是+-号 如果是要去掉这一项
遍历数组取数字字符相加
 
/**
 * @param {string} str
 * @return {number}
 */
var myAtoi = function (str) {
  const re = /^[0-9]$/; // 正则匹配每一项是不是数字字符
  str = str.trim(); // 字符串前后空格
  str = str.split(' ')[0].split(''); // 通过空格分成子数组取第一项再拆成数组
  let positiveNum = true; // 判断是否是正数
  let result = 0; // 返回结果
  if (str[0] === '-') { // 如果数组第一项是+-那么删掉第一项并改成正数或复数
    positiveNum = false;
    str.splice(0, 1);
  } else if (str[0] === '+') str.splice(0, 1);
  for (let i = 0; i < str.length; i++) { // 循环数组
    if (re.test(str[i])) result += str[i]; // 如果是该项是数字字符,加入result
    else break; // 一旦出现不算数字字符的 直接退出循环
  }
  result = positiveNum ? parseInt(result) : (0 - parseInt(result)); // 判断结果取正数还是复数
  if (result >= 0) return Math.min(result, Math.pow(2, 31) - 1); // 判断两种极限的情况
  else return Math.max(result, Math.pow(-2, 31));
};

 

posted @ 2020-03-19 09:00  蓝小胖纸  阅读(172)  评论(0编辑  收藏  举报