# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
607171 | erto | 원숭이와 사과 나무 (IZhO12_apple) | C++17 | 410 ms | 262144 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
typedef long long int ll;
#define INF 1000000007
#define INF2 998244353
#define N (ll)(5e3+ 5)
using namespace std;
#define int ll
#define lsb(x) (x & (-x))
int m, g, h, t, cur=0;
struct Vertex {
int left, right;
int lazy=0;
int sum = 0;
Vertex *left_child = nullptr, *right_child = nullptr;
Vertex(int lb, int rb) {
left = lb;
right = rb;
}
void extend() {
if (!left_child && left < right) {
int t = (left + right) / 2;
left_child = new Vertex(left, t);
right_child = new Vertex(t + 1, right);
}
if(lazy == 1 && left_child){
left_child->lazy = 1;
right_child->lazy = 1;
left_child->sum = left_child->right - left_child->left + 1;
right_child->sum = right_child->right - right_child->left + 1;
lazy = 0;
}
}
void add(int lq, int rq) {
if(left > rq || right < lq)return;
if(left >= lq && right <= rq){
if(sum == right - left + 1)return;
lazy = 1;
sum = right - left + 1;
return;
}
extend();
left_child->add(lq, rq);
right_child->add(lq, rq);
sum = left_child->sum + right_child->sum;
}
int get_sum(int lq, int rq) {
if(!sum || left > rq || right < lq)return 0;
if (lq <= left && right <= rq){
return sum;
}
extend();
return left_child->get_sum(lq, rq) + right_child->get_sum(lq, rq);
}
};
void solve(){
cin >> m;
Vertex s(1, 1e9);
for(int i=1; i<=m; i++){
cin >> t >> g >> h;
if(t == 1){
cur = s.get_sum(g + cur, h + cur);
cout << cur << "\n";
}
else{
s.add(g + cur, h + cur);
}
}
}
signed main(){
ios_base::sync_with_stdio(0);
cin.tie(0);
int T = 1;
// cin>>T;
while (T--){
solve();
}
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |