Problem Description
You are given an integer array pref
of size n
. The goal is to find and return the array arr
of size n
that satisfies the following condition:
pref[i] = arr[0] ^ arr[1] ^ ... ^ arr[i]
Here, ^
denotes the bitwise-xor operation.
Example
Input
pref = [5, 2, 0, 3, 1]
Output
[5, 7, 2, 3, 2]
Explanation
From the array [5, 7, 2, 3, 2]
, we have the following:
pref[0] = 5
pref[1] = 5 ^ 7 = 2
pref[2] = 5 ^ 7 ^ 2 = 0
pref[3] = 5 ^ 7 ^ 2 ^ 3 = 3
pref[4] = 5 ^ 7 ^ 2 ^ 3 ^ 2 = 1
Implementation Details
We provide a C++ solution using a class Solution
with a method findArray
.
class Solution {
public:
vector<int> findArray(vector<int>& pref) {
int n = pref.size();
vector<int> arr(n);
arr[0] = pref[0]; // The first element of arr is equal to the first element of pref
// Iterate through the pref array to find the elements of arr
for (int i = 1; i < n; i++) {
arr[i] = pref[i] ^ pref[i - 1];
}
return arr;
}
};
Explanation
- Initialize
n
with the size of the input arraypref
. - Create a vector
arr
to store the resulting array. - Set the first element of
arr
to be equal to the first element ofpref
. - Iterate through the
pref
array starting from index 1. - At each step, calculate
arr[i]
using the XOR operation with the current elementpref[i]
and the previous elementpref[i - 1]
. - Return the resulting
arr
.
This solution leverages the property of XOR operation to find the array arr that satisfies the given condition.
Feel free to include any additional information or context that might be relevant to your specific use case.