我首先想把一个数字转换为二进制,然后按位反转它。 像这样:
数字是793 = 1100011001
然后将二进制值转换为:0011100110
在JavaScript中,我可以执行以下操作:
var x = 793;
document.write(x.toString(2)); // gives 0011100110
这将给出该数字的二进制值。 但是如何进行位反转操作?
我尝试使用~
运算符,但它可能无法正常工作。输出结果为:-1100011010
我首先想把一个数字转换为二进制,然后按位反转它。 像这样:
数字是793 = 1100011001
然后将二进制值转换为:0011100110
在JavaScript中,我可以执行以下操作:
var x = 793;
document.write(x.toString(2)); // gives 0011100110
这将给出该数字的二进制值。 但是如何进行位反转操作?
我尝试使用~
运算符,但它可能无法正常工作。输出结果为:-1100011010
MooGoo的答案是正确的。
这里有一些关于正在发生的事情的信息... 假设这是一个64位整数。
793 = 1100011001
~793 = -794 = 1111111111111111111111111111111111111111111111111111110011100110
0x3ff = 1111111111
(-793 & 0x3ff) = 11100110
你可以使用以下代码来解决所有情况:
var x = 793; // input value
var y = x.toString(2);
var yl = y.length;
var mask = (Math.pow(2,yl)-1); // calculate mask
var result = ~x & mask;
document.write(result.toString(2)+"<br/>");
你需要使用位掩码。
(~793 & 0x3ff).toString(2) //11100110
或者使用异或运算
793 ^ 0x3ff
var x = 793;
var result = x ^ parseInt((new Array(x.toString(2).length+1)).join("1"),2);
(从PHP.JS中获取的str_repeat代码)
几年后重新审视,尝试:
var x = 793;
var result = parseInt(x.toString(2).replace(/[01]/g,function(n) {return 1-n;}),2);
我相信这样会更有效率...可能吧。完全可能也错了。不过没关系。
Number.prototype.negate = function() {return this ^ parseInt((new Array(this.toString(2).length+1)).join("1"),2);};
- 这样你就可以这样使用:var x = 793; var c = x.negate();
- Niet the Dark Absol793..toString(2).replace(/1/g, 'a').replace(/0/g, '1').replace(/a/g, '0')
,但你可能会导致某个6502 CPU熔断。 - MooGoo虽然代码不是最短的,但更易读。我的技巧类似于@Ivo Wetzel:
const bitwiseComplement = (N) => {
let binary = N.toString(2); // 793 is "1100011001" in binary
binary = binary.split('').map(x => {
return (x == 1) ? 0 : 1;
}).join('');
return binary; // with complement "0011100110" in binary
};
console.log(bitwiseComplement(793));
一行JavaScript解决方案。正则表达式/[0-1]/g
的意思是匹配下列列表中出现的单个字符[0-1]
。
const bitwiseComplement = (N) => {
return N.toString(2).replace(/[0-1]/g, (v) => (v == 1 ? 0 : 1));
};
console.log(bitwiseComplement(793));
我只是这样做
假设x = -11.3,它是来自某个地方的16位整数。
我的结果将进入变量r。
var r = ((x & 0x7FFF) ^ 0x7FFF)+1;
这是KISS原则。
& 0x7FFF
是多余的。 - vanowm更新
我不确定您是否想要一个反转值的字符串,如果是这样,您可以这样做:
function invert(x){
var e = x.toString(2).split('');
for(var i = 0, l = e.length; i < l; i++) {
e[i] = e[i] === '0' ? '1' : (e[i] === '1' ? '0' : e[i]);
}
return e.join('');
}
invert(793); // '0011100110'
invert(-793); // '-0011100110'
这也将保留前导零。
793 ^ -1
可以得到任何数字的按位反转值,只需要使用左操作数为-1
的运算符^
即可。 - Victor