#include using namespace std; using ll = long long; template using vt = vector; template using vvt = vector>; template using ttt = tuple; using tii = tuple; using vi = vector; #define rep(i,n) for(int i=0;i<(int)(n);i++) #define pb push_back #define mt make_tuple #define ALL(a) (a).begin(),(a).end() #define FST first #define SEC second #define DEB cerr<<"!"<0){if((n&1)==1)r=r*x%m;x=x*x%m;n>>=1;}return r%m;} inline ll lcm(ll d1, ll d2){return d1 / __gcd(d1, d2) * d2;} // IT 5000兆 欲しい /* Coding space */ using ll = long long; using ull = unsigned long long; ull seed; int next() { seed = seed ^ (seed << 13); seed = seed ^ (seed >> 7); seed = seed ^ (seed << 17); return (seed >> 33); } template struct FT{ vector d; FT(size_t n):d(n+1){} T sum(size_t i){T s{};for(++i;i>0;i-=i&-i)s+=d[i];return s;} T sum(size_t i,size_t j){return i?sum(j)-sum(i-1):sum(j);} void add(size_t i,T x){for(++i;i struct lazy_FT{ FT d,lazy; // value, lazy array lazy_FT(size_t n):d(n+1),lazy(n+1){} void add(size_t l, size_t r,T val){ // log(n) d.add(l, r, val); lazy.add(l, r, (l - 1) * val); lazy.add(r + 1, (-r + l - 1) * val); } T sum(size_t i){return d.sum(i) * i - lazy.sum(i);} // log(n) T sum(size_t i, size_t j){return sum(j) - sum(i-1);} // log(n) }; vector A[10000]; const int D = 300000; FT cnt_A(100000); void Add(int in){ A[in/D].pb(in); cnt_A.add(in/D,1); } int c(int x){ int ret = lower_bound(ALL(A[x/D]),x) - A[x/D].begin(); if(x/D > 0) ret += cnt_A.sum(0,x/D - 1); return ret; } int main() { int n, q; cin >> n >> q >> seed; for (int i = 0; i < 10000; i++) next(); vector a(n); for (int i = 0; i < n; i++) Add(next()); rep(i,10000) sort(ALL(A[i])); ll sm = 0; for (int i = 0; i < q; i++) { int x = next(); int cnt = 0; cnt = c(x); sm ^= ll(cnt) * i; } cout << sm << endl; return 0; }