#pragma comment(linker, "/STACK:1024000000,1024000000") #include<bits/stdc++.h> usingnamespace std; using i64 = longlong; using u64 = unsignedlonglong; using u32 = unsigned; using u128 = unsigned __int128;
voidsolve(){ int n; cin >> n;
vector<i64> a(n); for (int i = 0; i < n; i++) { cin >> a[i]; }
i64 ans = 1; if (n % 2 == 0) { for (int i = 0; i < n; i += 2) { ans = max(ans, a[i + 1] - a[i]); } } else { ans = 1E18; for (int i = 0; i < n; i += 2) { i64 res = 1; for (int j = 0; j < n; j += 2) { if (i == j) { j--; continue; } res = max(res, a[j + 1] - a[j]); } ans = min(ans, res); } }
#pragma comment(linker, "/STACK:1024000000,1024000000") #include<bits/stdc++.h> usingnamespace std; using i64 = longlong; using u64 = unsignedlonglong; using u32 = unsigned; using u128 = unsigned __int128;
voidsolve(){ int n; cin >> n; string s; cin >> s;
i64 ans = 1LL * n * (n + 1) / 2; int need = 0; for (int i = n - 1; i >= 0; i--) { if (s[i] == '1' && need + 1 <= i) { ans -= i + 1; need++; } else { need = max(0, need - 1); } }
for (int i = 0; i <= n; i++) { ss[i + 1] = ss[i] + s0[i]; }
auto query = [&](i64 x) { i64 l = 0, r = n; while (l < r) { int mid = (l + r + 1) / 2; if (x >= 1LL * mid * (n + n - mid + 1) / 2) { l = mid; } else { r = mid - 1; } }
i64 res = 0; res += s0[n + 1] * l; res -= ss[l]; res -= s0[l] * (n + 1); res += s1[l]; x -= 1LL * l * (n + n - l + 1) / 2; res += s0[l + x + 1] - s0[l]; res -= pre[l] * (x + 1);
return res; };
int q; cin >> q; while (q--) { i64 l, r; cin >> l >> r; cout << query(r) - query(l - 1) << '\n'; } }