104062024-04-01 20:57:09Valaki2Xorzótáblacpp17Hibás válasz 0/1001.746s36512 KiB
#include <bits/stdc++.h>
using namespace std;

#define int long long
#define pb push_back
#define mp make_pair
#define pii pair<int, int>
#define fi first
#define se second

const int maxn = 1e5;

int n, m;
int a[1 + maxn];
int b[1 + maxn];

int len;
int halflen;

struct event {
    int type;
    // 0 - update
    // 1 - query
    int pos;
    bool operator < (const event &other) const {
        if(pos == other.pos) {
            return type < other.type;
        }
        return pos < other.pos;
    }
};

int get_bit(int bit) {
    len = (1 << (bit + 1));
    halflen = (1 << bit);
    vector<event> events;
    for(int i = 1; i <= m; i++) {
        int bi = b[i] % len;
        int l = (halflen - bi + 2 * len) % len;
        int r = (len - 1 - bi + 2 * len) % len;
        if(l == 0) {
            events.pb(event{1, r});
        } else {
            if(l < r) {
                events.pb(event{1, l - 1});
                events.pb(event{1, r});
            } else {
                events.pb(event{1, r});
                events.pb(event{1, l - 1});
                events.pb(event{1, len - 1});
            }
        }
    }
    for(int i = 1; i <= n; i++) {
        int ai = a[i] % len;
        events.pb(event{0, ai});
    }
    sort(events.begin(), events.end());
    int res = 0;
    int cnt = 0;
    for(event e : events) {
        if(e.type == 0) {
            cnt++;
            cnt %= 2;
        } else {
            res += cnt;
        }
    }
    res %= 2;
    return res;
}

void solve() {
    cin >> n >> m;
    for(int i = 1; i <= n; i++) {
        cin >> a[i];
    }
    for(int i = 1; i <= m; i++) {
        cin >> b[i];
    }
    int ans = 0;
    for(int j = 0; j < 31; j++) {
        ans += (get_bit(j) << j);
    }
    cout << ans << "\n";
}

signed main() {
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr);
    solve();
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva3ms1840 KiB
2Hibás válasz1.45s30576 KiB
subtask20/14
3Hibás válasz3ms2248 KiB
4Hibás válasz9ms2580 KiB
5Elfogadva4ms2380 KiB
6Elfogadva6ms2700 KiB
7Elfogadva9ms3000 KiB
8Elfogadva12ms3020 KiB
9Hibás válasz14ms3284 KiB
subtask30/14
10Elfogadva3ms3112 KiB
11Elfogadva1.583s33632 KiB
12Elfogadva1.583s32436 KiB
13Hibás válasz1.746s34292 KiB
14Hibás válasz1.746s34092 KiB
subtask40/14
15Elfogadva1.12s31712 KiB
16Elfogadva1.31s32696 KiB
17Hibás válasz1.069s31360 KiB
18Elfogadva1.491s34528 KiB
19Elfogadva1.475s34660 KiB
subtask50/21
20Hibás válasz172ms10964 KiB
21Elfogadva898ms22444 KiB
22Elfogadva861ms21936 KiB
23Elfogadva1.309s33888 KiB
24Elfogadva1.358s34232 KiB
25Hibás válasz1s36496 KiB
subtask60/37
26Elfogadva118ms7936 KiB
27Hibás válasz1.25s31160 KiB
28Hibás válasz1.021s21960 KiB
29Elfogadva1.427s32156 KiB
30Elfogadva1.741s34968 KiB
31Elfogadva1.746s34988 KiB
32Elfogadva1.192s36512 KiB
33Hibás válasz1.741s36064 KiB
34Elfogadva1.743s36056 KiB