Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
98108 | zhangmaozheng | 早凉的程序2 | C++ | 运行超时 | 10 | 4000 MS | 1836 KB | 737 | 2023-08-14 12:18:29 |
#include <bits/stdc++.h> #define mid (l + r >> 1) #define lc (id << 1) #define rc (id << 1 | 1) #define int long long using namespace std; int n, m, p, l, r, f1 = 1, f2 = 1, f3 = 1; int a[200005], sum[400005], sum1[200005]; signed main(){ cin >> n >> m >> p; for (int i = 1; i <= n; i++){ cin >> a[i]; if (a[i] < p) f3 = 0; } if (f3){ for (int i = 1; i <= n; i++) a[i] -= p, sum[i] = sum[i - 1] + a[i]; while(m--){ scanf("%d%d", &l, &r); printf("%lld\n", sum[r] - sum[l - 1]); } return 0; } while(m--){ scanf("%d%d", &l, &r); long long ans = 0; for (int i = l; i <= r; i++){ ans += a[i]; if (ans >= p) ans -= p; } printf("%lld\n",ans); } return 0; }