zoukankan      html  css  js  c++  java
  • 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));
    };
  • 相关阅读:
    Ueditor使用以及遇到的问题
    自己写一个分页PageHelper
    C#_IO操作_查询指定文件夹下的每个子文件夹占空间的大小
    C#发邮件_EmailHelper
    位运算反(~)与(&)异或(^)或(|)右移(>>)左移(<<)
    shell命令快捷键
    Openstack Day1简介及虚拟环境搭建
    VirtualBox双网卡搭建Linux虚拟实验环境
    git 学习笔记
    python socket 网络编程
  • 原文地址:https://www.cnblogs.com/lanpang9661/p/12522012.html
Copyright © 2011-2022 走看看