用一行代码把一个数的左边第i位变成反码

问题遇到的现象和发生背景

描述
写出函数中缺失的部分,使得函数返回值为一个整数,该整数的左边i位是n的左边i位取反,其余位和n相同
请使用【一行代码】补全bitManipulation3函数使得程序能达到上述的功能

#include <iostream>
using namespace std;

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

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

输入
第一行是整数 t,表示测试组数。
每组测试数据包含一行,是两个整数 n 和 i (1<=i<=32)。
输出
对每组输入数据,输出整型变量n中左边i位取反的结果。
样例输入
1
0 32
样例输出
-1
提示
注意i从1开始

问题相关代码,请勿粘贴截图
运行结果及报错内容

我不理解为什么它给的样例 0的左边第32位 就是第0位,替换成相反的不就是 1 吗,他给的答案是-1?

我的解答思路和尝试过的方法
我想要达到的结果

我这个运行结果也是1

左边是最高位,右边是最低位
右边第一个变1才是1
左边第一个变1是32768
如果是有符号数,那最左边是符号位,那就是-32768
变-1肯定不对,-1对应的二进制码是FFFF

注意了!是左面i位,不是左面第i位!0左面32位取反,也就是全部的位都变成1,而不是第32位变成1

return n^(1<<(32-i));这是我填的代码