This problem is quite crucial in the journey of someone studying data structures and algorithms. It is because it uses two important concepts i.e. prefix sum and the XOR operation.
Firstly, whenever you need a constant time window sum in an array, think of a prefix sum array
. A prefix sum array is calculated by adding all the previous elements until i-1
and storing the current cumulative sum at prefix_sum[i]
.
Second, an XOR operation is reversible. Learn more about XOR here - 2433 Find the Original Array of Prefix Xor
Code
Python3
Big O Analysis
-
Runtime
The runtime complexity here is since we are visiting all elements in the array only once.
-
Memory
The memory usage is since we use are using a list to store prefix XORs and the result.
— A