제출 #960827

#제출 시각아이디문제언어결과실행 시간메모리
960827pragmatistSegments (IZhO18_segments)C++17
7 / 100
5090 ms6704 KiB
#include <bits/stdc++.h> using namespace std; const int N = 2e5+7; int n, t; pair<int, int> a[N]; int main() { ios_base::sync_with_stdio(false); cin.tie(0); cin >> n >> t; int ans = 0, timer = 0; multiset<pair<int, int> > s; for(int i = 1; i <= n; ++i) { char tp; cin >> tp; if(tp == '1') { int l, r; cin >> l >> r; l = (l^(t*ans)); r = (r^(t*ans)); if(l>r) { swap(l, r); } a[++timer] = {l, r}; s.insert({l, r}); } else if(tp == '2') { int id; cin >> id; auto it = s.find(a[id]); s.erase(it); } else { int l, r, k; cin >> l >> r >> k; l = (l^(t*ans)); r = (r^(t*ans)); if(l>r) { swap(l, r); } int res = 0; for(auto [x, y] : s) { int len = max(0, min(y, r)-max(x, l)+1); if(len >= k) { res++; } } cout << res << "\n"; ans = res; } } return 0; }
#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...