Hey all,

I was trying this problem Big Number Array on Hackerearth. I tried simple brute force but only one test case passed.

I also looked at the editorial but they only published the code and not the explanation.

It will be very helpful if someone could explain the approach.

Thanks in advance!

Flipping the l-th bit to r-th bit in a number is same as XORing that number with a number having 1s only in positions from βlβ to βrβ. Letβs denote the number whose first βkβ bits are 1s and the remaining are 0s as X_{k} . So, if you flip the bits from position βlβ to position βrβ in a number βAβ, the resulting number will be equal to A XOR X_{l-1} XOR X_{r}. But, since l,r are big, it is impossible to actually XOR with those numbers.

So, we will use some random numbers to take the place of each X_{k}. Suppose that we will assign each X_{k} a value that is uniformly randomly selected from the range [0,2^{h}-1]. Each update will be a range XOR operation now. However, there is a problem with this approach, because there is a chance that two numbers might end up getting the same value (after XORing), even though the bits present in them are different. It is impossible to completely eliminate this, but we can decrease the probability of this happening, to a point where its almost negligible. This can be done by choosing a suitably large value for the range of random numbers.

If the numbers are uniformly randomly chosen from the range [0,2^{h}-1], a sequence of XOR operations will give us a result in the same range as well. Irrespective of the length of the sequence, the probability of the result being equal to any number in the range [0,2^{h}-1] is same (why?). In the worst case, all the βNβ numbers will be different, and we need to minimise the probability that the value we get after performing XOR operations on any two numbers out of them are equal. If you set h=64, and N=10^5, the probability of getting a random collision (two numbers with same value) will be less than 10^{-9} ( Birthday attack - Wikipedia ).

1 Like