位运算实现i自增(i++)
今天写python的时候习惯性写了 i++ 来自增,果不其然,SyntaxError!python的数值对象是不可改变的,只能用 i = i + 1 进行变量赋值操作。(这里相当于新创建一个变量i)
但这样看着好别扭,可能是习惯性 i++ 了,于是就思考着能否用位运算的方式来实现 i 的自增(思维乱跳)
或运算实现
i = (i|1) + (i&1)
如果是偶数,末位为0,与1进行或运算后值为1,其他位不变,实现+1操作。
如果是奇数,末尾为1,与1进行或运算后各位不变,手动+1。
取反运算实现
i = -~i
~i = - (i + 1) 乘上 -1 后即为 i + 1
异或运算实现
(i^1) + ((i&1)<<1)
异或相当于不进位加法,当某位为 1 时,我们对其进行手动进位,即加上 10 (二进制)
就想到这三个,对比了一下取反操作更为简洁。
纯属无聊,娱乐一下~~
#include<bits/stdc++.h>
using namespace std;
int main()
{
int i;
cin >> i;
cout << (i|1) + (i&1) << endl;
cout << -~i << endl;
cout << (i^1) + ((i&1)<<1) << endl;
}