关于parseInt面试题let arr = [27.2,0,'0013','14px',123] arr = arr.map(parseInt)

let arr = [10.18, 0, 10, 25, 23]
arr = arr.map(parseInt)
console.log(arr)

 arr = arr.map((item, index) => {
      // arr.map原本的意思:
       // 循环遍历数组中的某一项就会触发回调函数
       // 每一次还会传递当前项和当前项的索引
 })
  • 但是这道题map里不是我们自定义的匿名的回调函数了,

  • 而是放的parseInt,所以parseInt现在是map循环时的回调函数。

  • parseInt也是个函数,比较常见的用法就是: parseInt('12px12') => 从左侧开始查找有效字符,遇到无效字符就停止查找=>12

  • (parseInt特点:括号里不管是什么值,都要转成字符串,从最左侧查找,遇到无效字符停止查找)

  • arr.map遍历第一项的时候就相当于把回调函数parseInt执行,并且传了两个参数item和index

  • arr.map会循环五次

  • parseInt('10.18', 0) => parseInt不识别小数点 => parseInt('10', 0),
    parseInt('0', 1)
    parseInt('10', 2)
    parseInt('25', 3)
    parseInt('23', 4)

  • parseInt语法:parseInt([value],[radix])
    ->[radix]这个值是一个进制,不写或者写0都是按照10处理(特殊情况:如果value时以0X开头,则默认值是16而不是10)
    ->[radix]取值范围:2-36之间,如果不在这个之间,整个程序运行的结果一定是NaN
    ->parseInt([value],[radix]):意思是把[value]看作[radix]进制,然后转化为十进制

  • 如何把一个其他进制的值转为十进制呢?
    举个例子:把147(八进制)转为十进制
    这里有个位权值的概念:[位权值:每一位的权重,个位是0,十位十1,百位是2...]
    计算规则:[value]的每一位 * [radix] ^ 位权值,然后把得到的值相加,
    147的计算规则就是:1 * 8 ^ 2 + 4 * 8 ^ 1 + 7 * 8 ^ 0 = 64+32+7 = 103

    如果是带小数的该怎么计算呢?比如:12.23(四进制) => 十进制
    小数点前的计算:1 * 4 ^ 1+2 * 4 ^ 0
    小数点后的计算:小数点后的第一位位权值-1,第二位-2....
    2 * 4 ^ -1 + 3 * 4 ^ -2
    结果就是:1 * 4 ^ 1 + 2 * 4 ^ 0 + 2 * 4 ^ -1 + 3 * 4 ^ -2
    这时有个问题:负次幂该怎么计算呢?
    4^-1 = 1/4
    4^-2 = 1/4 * 4
    ....
    所以最终结果就是:4+2+0.5+0.1875 = 6.6875

  • 找到规律和计算规则后开始计算正题:

    parseInt('10.18', 0) =>从字符串左侧第一个字符开始查找,找到符合[radix]进制的值(遇到一个不合法的,则停止
    查找),把找到的值变为数字,再按照把[radix]转为十进制的规则处理
    [radix]如果是0或者不写,就默认为十进制,十进制的10转为十进制肯定还是10
    parseInt('10', 0) => 10

    parseInt('0', 1) => 1不在2-36之间,所以运行结果是NaN

    parseInt('10', 2)
    把10看作二进制,最后转为10进制
    1 * 2 ^ 1 + 0 * 2 ^ 0 = 2

    parseInt('25', 3)
    5不是再三进制范围内=> parseInt('2', 3)
    把2 当作3进制转为10进制
    2 * 3 ^ 0 = 2

    parseInt('23', 4)
    把23 当作4进制转为10进制
    2 * 4 ^ 1+ 3 * 4 ^ 0 = 11

    所以console.log(arr) => [10, NaN, 2, 2, 11]
    

特殊:

parseInt(0023) //  -> 19

按照我们刚才的逻辑讲,应该是23才对,可为什么结果是19呢?
是因为:

  • 浏览器遇到0开始的数字,则认为是8进制
  • 浏览器中我们看到的数字都是十进制的,所以默认就存在:把8进制转换为十进制的操作:
    2 * 8 ^ 1 + 3 * 8 ^ 0 = 19
    parseInt(19) -> 19

注意:再强调一下,这不是parseInt的功能,而是浏览器的

直接在浏览器中输出 0023,得到的也是19


image.png

扩展题目:
有99瓶水和1瓶毒药,老鼠喝了毒药7天后会死,(毒药和水可以被多只老鼠多次喝),问:七天后,最少消耗多少只老鼠可以区分出毒药?

答案:
用二进制给瓶编号, 是7位数, 用7只老鼠分别喝对应的位数为1的瓶子
七天后,例如1 4 5老鼠死了, 有毒的编号是 1001100

image.png

你可能感兴趣的:(关于parseInt面试题let arr = [27.2,0,'0013','14px',123] arr = arr.map(parseInt))