Maximum XOR After Operations: You are given a 0-indexed integer array nums. In one operation, select any non-negative integer x and an index i, then update nums[i] to be equal to nums[i] AND (nums[i] XOR x).
Note that AND is the bitwise AND operation and XOR is the bitwise XOR operation.
Return the maximum possible bitwise XOR of all elements of nums after applying the operation any number of times.
Example 1:
Input: nums = [3,2,4,6] Output: 7 Explanation: Apply the operation with x = 4 and i = 3, num[3] = 6 AND (6 XOR 4) = 6 AND 2 = 2. Now, nums = [3, 2, 4, 2] and the bitwise XOR of all the elements = 3 XOR 2 XOR 4 XOR 2 = 7. It can be shown that 7 is the maximum possible bitwise XOR. Note that other operations may be used to achieve a bitwise XOR of 7.
Example 2:
Input: nums = [1,2,3,9,2] Output: 11 Explanation: Apply the operation zero times. The bitwise XOR of all the elements = 1 XOR 2 XOR 3 XOR 9 XOR 2 = 11. It can be shown that 11 is the maximum possible bitwise XOR.
Constraints:
- 1 <= nums.length <= 105
- 0 <= nums[i] <= 108
Solution
Explanation
The maximum possible result is res = A[0] || A[1] || A[2] ... and it’s realisable.
Prove
Now we approve it’s realisable.
Assume result is best = XOR(A[i]) and best < res above.
There is at least one-bit difference between best and res, assume it’s x = 1 << k.
We can find at least a A[i] that A[i] & x = x.
we apply x on A[i], A[i] is updated to A[i] & (A[i] ^ x) = A[i] ^ x.
We had best = XOR(A[i]) as said above,
now we have best2 = XOR(A[i]) ^ x,
so we get a better best2 > best, where we prove by contradiction.
Complexity
Time O(n)
Space O(1)
Java
    public int maximumXOR(int[] nums) {
        int res = 0;
        for (int a: nums)
            res |= a;
        return res;
    }
C++
    int maximumXOR(vector<int>& nums) {
        int res = 0;
        for (int a : nums)
            res |= a;
        return res;
    }
C++
    int maximumXOR(vector<int>& nums) {
        return reduce(nums.begin(), nums.end(), 0, bit_or());
    }
Python
    def maximumXOR(self, nums):
        return reduce(ior, nums)Happy Learning – If you require any further information, feel free to contact me.
![[Solved] Maximum XOR After Operations LeetCode Contest Problem [Solved] Maximum XOR After Operations LeetCode Contest Problem](https://realcoder.techss24.com/wp-content/uploads/2022/06/Solved-Maximum-XOR-After-Operations-LeetCode-Contest-Problem.png)
![[Solved] First Letter to Appear Twice LeetCode Contest Problem](https://realcoder.techss24.com/wp-content/uploads/2022/07/Solved-First-Letter-to-Appear-Twice-LeetCode-Contest-Problem-300x200.png)
![[Solved] Count Number of Bad Pairs LeetCode Contest](https://realcoder.techss24.com/wp-content/uploads/2022/08/Solved-Count-Number-of-Bad-Pairs-LeetCode-Contest-300x200.png)
![[Solved] Fair Distribution of Cookies LeetCode Contest Problem](https://realcoder.techss24.com/wp-content/uploads/2022/06/Solved-Fair-Distribution-of-Cookies-LeetCode-Contest-Problem-300x200.png)