이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
using pi = pair<int, int>;
using pl = pair<long long, long long>;
using vi = vector<int>;
using vl = vector<long long>;
using vpi = vector<pair<int, int>>;
using vpl = vector<pair<long long, long long>>;
#define fur(i, a, b) for(ll i = a; i <= (ll)b; ++i)
#define ruf(i, a, b) for(ll i = a; i >= (ll)b; --i)
#define fr first
#define sc second
#define mp make_pair
#define pb push_back
#define eb emplace_back
#define nl "\n"
#define all(x) (x).begin(),(x).end()
#define rall(x) (x).rbegin(),(x).rend()
const ll mxn = 3e5L + 1;
ll n, q;
ll d[mxn];
ll a[mxn];
struct item {
ll zer, one, zlt, zrt, olt, ort;
item() {
zer = one = zlt = zrt = olt = ort = 0;
}
};
struct SegTree {
ll n;
item id;
vector<item> tree;
SegTree(ll N) {
init(N, id);
}
void init(ll N, item x) {
id = x;
n = N;
while(__builtin_popcountll(n) != 1) ++n;
tree.resize(2*n, id);
}
void build() {
build(1, 0, n - 1);
}
void build(ll x, ll lx, ll rx) {
if(lx == rx)
return;
ll d = (lx + rx) / 2;
build(2*x, lx, d);
build(2*x + 1, d + 1, rx);
tree[x] = merge(tree[2*x], tree[2*x + 1], (rx - lx + 1) / 2);
}
item query(ll x, ll lx, ll rx, ll l, ll r) {
if(lx > r || rx < l)
return id;
if(lx >= l && rx <= r)
return tree[x];
ll d = (lx + rx) / 2;
item a = query(2*x, lx, d, l, r);
item b = query(2*x + 1, d + 1, rx, l, r);
return merge(a, b, (rx - lx + 1) / 2);
}
ll query(ll ql, ll qh) {
item res = query(1, 0, n - 1, ql, qh);
return max(res.one, res.zer);
}
item merge(item lhs, item rhs, ll sz) {
item ans;
// ones
ans.olt = lhs.olt;
if(lhs.olt == sz)
ans.olt += rhs.olt;
ans.ort = rhs.ort;
if(rhs.ort == sz) {
ans.ort += lhs.ort;
}
ans.one = max({lhs.one, rhs.one, lhs.ort + rhs.olt});
// zeroes
ans.zlt = lhs.zlt;
if(lhs.zlt == sz) {
ans.zlt += rhs.zlt;
}
ans.zrt = rhs.zrt;
if(rhs.zrt == sz) {
ans.zrt += lhs.zrt;
}
ans.zer = max({lhs.zer, rhs.zer, lhs.zrt + rhs.zlt});
return ans;
}
};
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cin >> n >> q;
fur(i, 1, n) {
cin >> d[i];
}
ruf(i, n, 2) {
d[i] = d[i] - d[i - 1];
}
d[1] = d[2] + 1;
// fur(i, 1, n) {
// cout << d[i] << ' ';
// }
// cout << nl;
ll cur = 1;
fur(i, 1, n) {
ll j = i;
a[j] = cur;
while(j + 1 <= n && d[j + 1] == d[i]) {
++j;
a[j] = cur;
}
cur = 1 - cur;
i = j;
}
// fur(i, 1, n) {
// cout << a[i] << ' ';
// }
// cout << nl;
SegTree st(n);
fur(i, 1, n) {
if(a[i] == 0) {
st.tree[i - 1 + st.n].zer = 1;
st.tree[i - 1 + st.n].zrt = 1;
st.tree[i - 1 + st.n].zlt = 1;
} else {
st.tree[i - 1 + st.n].one = 1;
st.tree[i - 1 + st.n].ort = 1;
st.tree[i - 1 + st.n].olt = 1;
}
}
st.build();
while(q--) {
ll t;
cin >> t;
if(t == 1) {
ll l, r, s, c;
cin >> l >> r >> s >> c;
}
else if(t == 2) {
ll l, r, s, c;
cin >> l >> r >> s >> c;
}
else if(t == 3) {
ll l, r;
cin >> l >> r;
ll res = st.query(l - 1, r - 1);
if(res != r - l + 1)
++res;
cout << res << nl;
}
}
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |