需求:
0 -> 进行一个操作 -> 1
1 -> 进行一个操作 -> 2
2 -> 进行一个操作 -> 1
例如
let a = 0
a ^= a+1 // 1
a ^= a+1 // 3
a ^= a+1 // 1
使用按位异或就能满足 第一种 和 第三种的表现,但是第二种就不行
###// 如果要用位操作,先抹去第 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
语法是非常优雅的,代码不以句短为荣,只以难懂为耻(没错,难懂说的就是我这种写法)。