- categories: Code, Interview Question, leetcode, Medium
- source: https://leetcode.com/problems/neighboring-bitwise-xor
- topics: Bit Manipulation
A 0-indexed array derived with length n is derived by computing the bitwise XOR (⊕) of adjacent values in a binary array original of length n.
Specifically, for each index i in the range [0, n - 1]:
- If
i = n - 1, thenderived[i] = original[i] ⊕ original[0]. - Otherwise,
derived[i] = original[i] ⊕ original[i + 1].
Given an array derived, your task is to determine whether there exists a valid binary array original that could have formed derived.
Return true if such an array exists or false otherwise.
- A binary array is an array containing only 0’s and 1’s
Idea
Observe that XOR is associative and commutative and if we multiply all numbers ⇒ every number will be repeated twice
class Solution:
def doesValidArrayExist(self, derived: List[int]) -> bool:
aggr = 0
for t in derived:
aggr ^= t
return aggr == 0