Problem D

Statement
Copy Copied
Description:
You are given n integers a1, a2, ..., an. Denote this list of integers as T.

Let f(L) be a function that takes in a non-empty list of integers L.

The function will output another integer as follows:

- First, all integers in L are padded with leading zeros so they are all the same length as the maximum length number in L.
- We will construct a string where the i-th character is the minimum of the i-th character in padded input numbers.
- The output is the number representing the string interpreted in base 10.

For example f(10, 9) = 0, f(123, 321) = 121, f(530, 932, 81) = 30.

Define the function

$$$$

In other words, G(x) is the sum of squares of sum of elements of nonempty subsequences of T that evaluate to x when plugged into f modulo 1 000 000 007, then multiplied by x. The last multiplication is not modded.

You would like to compute G(0), G(1), ..., G(999 999). To reduce the output size, print the value $$G(0) \oplus G(1) \oplus G(2) \oplus \ldots \oplus G(999\ 999)$$, where $$\bigcirc$$ denotes the bitwise XOR operator.

Input Format:
The first line contains the integer n (1 ≤ n ≤ 1 000 000) — the size of list T.

The next line contains n space-separated integers, a1, a2, ..., an (0 ≤ ai ≤ 999 999) — the elements of the list.

Output Format:
Output a single integer, the answer to the problem.

Note:
For the first sample, the nonzero values of G are G(121) = 144 611 577, G(123) = 58 401 999, G(321) = 279 403 857, G(555) = 170 953 875. The bitwise XOR of these numbers is equal to 292 711 924.

For example, $$G(123) = 123 \cdot \left( ( ( 1 2 3 ) ^ { 2 } + ( 1 2 3 + 5 5 5 ) ^ { 2 } ) \right) \bmod 100000007 = 58401999$$, since the subsequences [123] and [123, 555] evaluate to 123 when plugged into f.

For the second sample, we have $$G(999\ 999) = 999\ 999 \cdot (999\ 999^2 \bmod 1\ 000\ 000\ 007)$$

For the last sample, we have $$G(1) = \sum_{i=1}^{10} {10 \choose i} i^2 = 28160$$, where $${ \binom { 10 } { i } }$$ is the binomial coefficient.