求一个js的二进制问题

需求:

0 -> 进行一个操作 -> 1
1 -> 进行一个操作 -> 2
2 -> 进行一个操作 -> 1

例如

let a = 0
a ^= a+1 // 1
a ^= a+1 // 3
a ^= a+1 // 1

使用按位异或就能满足 第一种 和 第三种的表现,但是第二种就不行
阅读 1.7k
2 个回答
// 如果要用位操作,先抹去第 2 位(就是把 2 变成 0)再加 1 
function func1(n) {
    return (n & 0x01) + 1;
}

// 其实看规律跟奇偶有关,所以
function func2(n) {
    return n % 2 + 1;
}

[0, 1, 2].forEach(n => console.log(n, "->", func1(n), func2(n)));

// 0 -> 1 1
// 1 -> 2 2
// 2 -> 1 1

来个纯位运算版本:

const p = t => ((t & 1) << 1) | ((t ^ 1) & 1);

if/else语法是非常优雅的,代码不以句短为荣,只以难懂为耻(没错,难懂说的就是我这种写法)。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题