用 JavaScript 交换十进制数的相邻二进制位以产生另一个十进制数
问题
我们需要编写一个接收数字的 JavaScript 函数。
我们的函数应迭代数字的二进制等效项并交换其相邻位以构建新的二进制。最后,我们的函数应返回新二进制的十进制等效项。
示例
以下是代码 -
const num = 13;
const swapBits = (num) => {
let arr = num.toString(2).split('');
if(arr.length % 2){
arr.unshift(0);
}
for(let i = 0; i < arr.length - 1; i = i + 2) {
[arr[i], arr[i + 1]] = [arr[i + 1], arr[i]];
}
return +('0b' + arr.join(''));
}
console.log(swapBits(num));输出
14
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP