每日JavaScript-30 十进制转二进制及位运算

先写了一个生成连续正整数的函数,调用JavaScript自带的toString(2)就可以实现十进制转换为二进制。注意的是,调用toSrtring()会将number类型隐式转换为string类型。

function to2(start, end) {  
return Array.from({length : end - start + 1}).map((value, index) => value = +(index + 1).toString(2))}
let res = to2(1, 100).reduce((acc, cur) => acc + ' ' + cur, [])
console.log(res)

接下来,我自己动手写一个十进制转二进制的函数,原理是常用的短除法。要主义的是,取证函数的区别。

Math.floor Math.ceil & Math.round

Math.floor 是向下取整
Math.ceil是向上取整
Math.round是四舍五入(稍有不同,以后更新)

一个写了用数组保存结果,用字符串保存结果还有使用位运算(最推荐)三个版本
每日JavaScript-30 十进制转二进制及位运算

每日JavaScript-30 十进制转二进制及位运算
位运算版
每日JavaScript-30 十进制转二进制及位运算
补充10进制转化为二进制

function twoToTen(num) {
  if (typeof num === 'number') num = num.toString()
  let res = 0
  const len = num.length
  for (let i = 0; i < len; i++) {
    res += +num[len - i - 1] * Math.pow(2, i)
  }
  return res
}

console.log(twoToTen(10))