Submission #775298

#TimeUsernameProblemLanguageResultExecution timeMemory
775298CESxRhinoAddk (eJOI21_addk)C++17
0 / 100
2099 ms3404 KiB
#include<iostream> #include<deque> using namespace std; long long int lazy[1000005]; long long int seg[1000005]; long long int a[100005]; void push(int id,int left,int right) { int mid = (left + right) / 2; seg[id * 2] += lazy[id] * (mid - left + 1); seg[id * 2 + 1] += lazy[id] * (right - mid); lazy[id * 2] += lazy[id]; lazy[id * 2 + 1] += lazy[id]; lazy[id] = 0; } void update(int id,int l,int r,int u,int v,int val) { if (u > v) return; if (u == l and v == r) { seg[id] += val * (v - u + 1); lazy[id] += val; return; } push(id, l, r); int mid = (l + r) / 2; update(id * 2, l, mid, u, min(v, mid), val); update(id * 2 + 1, mid + 1, r, max(u, mid + 1), v, val); seg[id] = seg[id * 2] + seg[id * 2 + 1]; } long long int get(int id,int l,int r,int u,int v) { if(u > v) { return 0; } if(u == l and v == r) { return seg[id]; } push(id,l,r); int mid = (l + r)/2; return get(id * 2,l,mid,u,min(v,mid)) + get(id * 2 + 1,mid + 1,r,max(u,mid + 1),v); } int main() { ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); int n,k,q; cin >> n >> k; int sum = 0; for(int i = 1;i <= n;i++) { cin >> a[i]; update(1,0,n,i,n,a[i]); } cin >> q; while(q--) { long long int type,l,r,x; cin >> type; if(type == 2) { cin >> l >> r >> x; int h = (l + x - 1); k = r - x; cout << get(1,0,n,h,r) - get(1,0,n,l - 1,k) << endl; } else { deque<int> v,d; for(int i = 0;i < k;i++) { int x; cin >> x; v.push_back(x); d.push_back(x); } d.push_back(d[0]); d.pop_front(); for(int i = 0;i < k;i++) { update(1,0,n,v[i],n,a[d[i]] - a[v[i]]); } int h = a[v[0]]; for(int i = 0;i < k - 1;i++) { a[v[i]] = a[d[i]]; } a[v[k - 1]] = h; } } }

Compilation message (stderr)

Main.cpp: In function 'int main()':
Main.cpp:51:6: warning: unused variable 'sum' [-Wunused-variable]
   51 |  int sum = 0;
      |      ^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...