Submission #564558

#TimeUsernameProblemLanguageResultExecution timeMemory
564558StickfishIntergalactic ship (IZhO19_xorsum)C++17
92 / 100
2073 ms4092 KiB
#include <iostream> #include <vector> #include <map> #include <bitset> using namespace std; using ll = long long; using ull = unsigned long long; const int MAXN = 1008; const ll MOD = 1000000007; const int MAXVAL = 128; const int HEY = MAXVAL * 3; int a[MAXN]; void updt(bitset<MAXVAL>& bs, int t) { if (bs[bs._Find_first() ^ t]) return; if (bs.count() == 64) { for (int i = 0; i < MAXVAL; ++i) bs[i] = 1; return; } for (int i = bs._Find_first(); i < MAXVAL; ++i) { if (bs[i]) bs[i ^ t] = bs[i]; } } ll pw(ll a, ll m) { if (!m) return 1; a %= MOD; if (m % 2) return a * pw(a, m - 1) % MOD; return pw(a * a, m / 2); } bool in(pair<int, int> sg, int i) { return sg.first <= i && i < sg.second; } vector<pair<int, int>> events[MAXN]; int change_ij[MAXN][MAXVAL]; int change_i[MAXN][MAXVAL]; int change_j[MAXN][MAXVAL]; struct sixple { ull first; ull second; ull third; ull fourth; ull fifth; ull sixth; bool operator<(sixple& s) { if (first != s.first) return first < s.first; if (second != s.second) return second < s.second; if (third != s.third) return third < s.third; if (fourth != s.fourth) return fourth < s.fourth; if (fifth != s.fifth) return fifth < s.fifth; return sixth < s.sixth; } }; signed main() { ios_base::sync_with_stdio(false); cin.tie(nullptr); cout.tie(nullptr); int n; cin >> n; for (int i = 0; i < n; ++i) cin >> a[i]; int q; cin >> q; for (int i = 0; i < q; ++i) { int l, r, x; cin >> l >> r >> x; --l; events[l].push_back({r, x}); events[r].push_back({l, x}); ++change_j[l][x]; --change_j[r][x]; } ll ans = 0; vector<int> genij0(MAXVAL, 0); bitset<MAXVAL> genbsij0; for (int i = 0; i < n; ++i) { for (auto [e, x] : events[i]) { if (e < i) genbsij0[x] = --genij0[x]; else { genbsij0[x] = ++genij0[x]; --change_ij[e][x]; ++change_j[e][x]; ++change_i[e][x]; } } vector<int> geni(MAXVAL); bitset<MAXVAL> genbsi; vector<int> genj(MAXVAL); bitset<MAXVAL> genbsj; vector<int> genij = genij0; bitset<MAXVAL> genbsij = genbsij0; for (int j = i; j < n; ++j) { if (j > i) { for (int x = 0; x < 128; ++x) { genbsij[x] = (genij[x] += change_ij[j][x]); genbsi[x] = (geni[x] += change_i[j][x]); genbsj[x] = (genj[x] += change_j[j][x]); } } bitset<MAXVAL> bsi; bitset<MAXVAL> bsj; bitset<MAXVAL> bsij; bsi[a[i]] = bsj[a[j]] = bsij[0] = 1; for (int xi = genbsi._Find_first(); xi < MAXVAL; xi = genbsi._Find_next(xi)) { updt(bsi, xi); if (bsi.count() == 128) continue; } for (int xj = genbsj._Find_first(); xj < MAXVAL; xj = genbsj._Find_next(xj)) { updt(bsj, xj); if (bsj.count() == 128) continue; } for (int xij = genbsij._Find_first(); xij < MAXVAL; xij = genbsij._Find_next(xij)) { updt(bsij, xij); if (bsij.count() == 128) continue; } ll addans = 0; if (bsij.count() == 128 && (bsi.count() == 128 || bsj.count() == 128)) { if (bsi.count() == 128) { addans += 64ll * 127 * 64 * 127 * bsj.count(); } else { addans += 64ll * 127 * 64 * 127 * bsi.count(); } } else { vector<int> xj_from_xij(MAXVAL); for (int xij = bsij._Find_first(); xij < MAXVAL; xij = bsij._Find_next(xij)) { if (bsj.count() == 128) { xj_from_xij[xij] = 64 * 127; } else { for (int xj = bsj._Find_first(); xj < MAXVAL; xj = bsj._Find_next(xj)) { xj_from_xij[xij] += xj ^ xij; } } } for (int xij = bsij._Find_first(); xij < MAXVAL; xij = bsij._Find_next(xij)) { if (bsi.count() == 128) { addans += xj_from_xij[xij] * 64 * 127; } else { for (int xi = bsi._Find_first(); xi < MAXVAL; xi = bsi._Find_next(xi)) { addans += xj_from_xij[xij] * (xi ^ xij); } } addans %= MOD; } } if (i != j) { addans *= 2; } addans *= (i + 1) * (n - j); addans %= MOD; addans *= pw(2, q); addans %= MOD; //cout << bsi.count() << ' ' << bsj.count() << ' ' << bsij.count() << endl; addans *= pw(bsi.count() * bsj.count() * bsij.count(), MOD - 2); ans += addans; ans %= MOD; //cout << i << ' ' << j << ": " << ans - ans0 << endl; } } cout << ans << endl; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...