QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#740103 | #9727. Barkley III | lonelywolf | Compile Error | / | / | C++23 | 3.8kb | 2024-11-13 01:14:21 | 2024-11-13 01:14:23 |
Judging History
你现在查看的是最新测评结果
- [2025-01-13 03:55:43]
- hack成功,自动添加数据
- (/hack/1447)
- [2024-11-13 01:14:23]
- 评测
- 测评结果:Compile Error
- 用时:0ms
- 内存:0kb
- [2024-11-13 01:14:21]
- 提交
answer
#include <bits/stdc++.h>
using namespace std;
using ull = unsigned long long;
struct Tag {
ull val = -1;
// void apply1(const Tag &t) {
// val &= t.val;
// }
};
struct Info {
ull val = -1, flg1 = -1, flg2 = 0;
int len = 1;
// void apply2(const Tag &t) {
// val &= t.val;
// if (len == 1) {
// flg1 = val;
// flg2 = ~val;
// } else {
// flg1 &= t.val;
// flg2 &= t.val;
// }
// }
};
// Info operator+(const Info &a, const Info &b) {
// return {a.val & b.val, a.flg1 & b.flg1, (a.flg1 & b.flg2) | (b.flg1 & a.flg2), a.len + b.len};
// }
const int N = 1000001;
Info info[N << 2];
Tag tag[N << 2];
int n;
// void pull(int p) {
// info[p] = info[p << 1] + info[p << 1 | 1];
// }
// void add(int p, const Tag &v) {
// info[p].apply2(v);
// tag[p].apply1(v);
// }
// void push(int p) {
// add(2 * p, tag[p]);
// add(2 * p + 1, tag[p]);
// tag[p] = Tag();
// }
// void modify(int p, int l, int r, int x, const Info &v) {
// if (l == r) {
// info[p] = v;
// return;
// }
// int m = (l + r) / 2;
// push(p);
// if (x <= m) {
// modify(p << 1, l, m, x, v);
// } else {
// modify(p << 1 | 1, m + 1, r, x, v);
// }
// pull(p);
// }
// void modify(int p, const Info &v) {
// modify(1, 1, n, p, v);
// }
// Info rangeQuery(int p, int l, int r, int x, int y) {
// if (l > y || r < x) {
// return Info();
// }
// if (l >= x && r <= y) {
// return info[p];
// }
// int m = (l + r) / 2;
// push(p);
// return rangeQuery(2 * p, l, m, x, y) + rangeQuery(2 * p + 1, m + 1, r, x, y);
// }
// Info rangeQuery(int l, int r) {
// return rangeQuery(1, 1, n, l, r);
// }
// void rangeApply(int p, int l, int r, int x, int y, const Tag &v) {
// if (l > y || r < x) {
// return;
// }
// if (l >= x && r <= y) {
// add(p, v);
// return;
// }
// int m = (l + r) / 2;
// push(p);
// rangeApply(2 * p, l, m, x, y, v);
// rangeApply(2 * p + 1, m + 1, r, x, y, v);
// pull(p);
// }
// void rangeApply(int l, int r, const Tag &v) {
// return rangeApply(1, 1, n, l, r, v);
// }
// template<class F>
// int findFirst(int p, int l, int r, int x, int y, const F &pred) {
// if (l > y || r < x || !pred(info[p])) {
// return -1;
// }
// if (l == r) {
// return l;
// }
// int m = (l + r) / 2;
// push(p);
// int res = findFirst(2 * p, l, m, x, y, pred);
// if (res == -1) {
// res = findFirst(2 * p + 1, m + 1, r, x, y, pred);
// }
// return res;
// }
// template<class F>
// int findFirst(int l, int r, const F &pred) {
// return findFirst(1, 1, n, l, r, pred);
// }
signed main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
// int q;
// cin >> n >> q;
// for (int i = 1; i <= n; i++) {
// ull x;
// cin >> x;
// modify(i, {x, x, ~x, 1});
// }
// while (q--) {
// int o;
// cin >> o;
// if (o == 1) {
// int l, r;
// ull x;
// cin >> l >> r >> x;
// rangeApply(l, r, {x});
// } else if (o == 2) {
// int p;
// ull x;
// cin >> p >> x;
// modify(p, {x, x, ~x, 1});
// } else {
// int l, r;
// cin >> l >> r;
// auto [v, a, b, _] = rangeQuery(l, r);
// if (b == 0) {
// cout << v << "\n";
// continue;
// }
// int k = __lg(b);
// int pos = findFirst(l, r, [&](Info p) {
// return !(p.val >> k & 1);
// });
// Info ans;
// if (pos != l) {
// ans = ans + rangeQuery(l, pos - 1);
// }
// if (pos != r) {
// ans = ans + rangeQuery(pos + 1, r);
// }
// cout << ans.val << "\n";
// }
// }
return 0;
}
Details
answer.code:169:1: fatal error: error writing to /tmp/ccwyuwf6.s: File too large 169 | } | ^ compilation terminated.