C++中的位运算技巧

2022-01-31  本文已影响0人  疋瓞

1、环境配置:

2、问题描述:

写出函数中缺失的部分,使得函数返回值为一个整数,该整数的第i位是n的第i位取反,其余位和n相同

请使用【一行代码】补全bitManipulation2函数使得程序能达到上述的功能
注:以二进制数最右边为第0个数。

#include <iostream>
using namespace std;

int bitManipulation2(int n, int i) {
// 在此处补充你的代码
}

int main() {
    int t, n, i;
    cin >> t;
    while (t--) {
        cin >> n >> i;
        cout << bitManipulation2(n, i) << endl;
    }
    return 0;
}

分析:

n&(1<<i)

可以实现获取n的第i位到底是0还是1。
柜内后可知满足条件的代码如下:

n^(1<<i)

就能实现功能。

总结:

上一篇 下一篇

猜你喜欢

热点阅读