码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2020-03-19 09:24:06      阅读:105      评论:0      收藏:0      [点我收藏+]

标签:需要   影响   遍历   positive   isp   pre   round   margin   说明   

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));
};

 

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

标签:需要   影响   遍历   positive   isp   pre   round   margin   说明   

原文地址:https://www.cnblogs.com/lanpang9661/p/12522012.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!