ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#211289 | #2398. 游戏 | Larryia | 0 | 31ms | 2220kb | C++11 | 1.9kb | 2024-08-10 12:22:20 | 2024-08-10 12:41:58 |
answer
#include <bits/stdc++.h>
#define lc (u << 1)
#define rc (u << 1 | 1)
using namespace std;
const int N = 1e6 + 10;
typedef long long ll;
struct tree {
int l, r;
ll sum, st, kt;
}tr[N];
int n, m;
void pushup(int u) {
tr[u].sum = tr[lc].sum + tr[rc].sum;
}
void build(int u, int l, int r) {
tr[u] = {l, r, 0, 0, 0};
if (l == r) return;
int mid = (l + r) >> 1;
build(lc, l, mid), build(rc, mid + 1, r);
}
void cal(int u, int k, int s) { //k首项,s公差
int x = tr[u].r - tr[u].l + 1; // 项数
tr[u].sum += k * x + s * (x - 1) * x / 2;
}
void pushdown(int u) {
cal(lc, tr[u].kt, tr[u].st);
cal(lc, (tr[u].kt + tr[rc].l - tr[u].l) * tr[u].st, tr[u].st);
tr[lc].kt += tr[u].kt;
tr[rc].kt += (tr[u].kt + tr[rc].l - tr[u].l) * tr[u].st;
tr[lc].st += tr[u].st;
tr[rc].st += tr[u].st;
tr[u].kt = tr[u].st = 0;
}
void change(int u, int l, int r, int s, int k) { // k是首项,s为公差
if (l > tr[u].r || r < tr[u].l) return;
if (l <= tr[u].l && tr[u].r <= r) {
cal(u, s * (k + tr[u].l - l), s);
tr[u].kt += s * (k + tr[u].l - l);
tr[u].st += s;
return;
}
pushdown(u);
change(lc, l, r, s, k);
change(rc, l, r, s, k);
pushup(u);
}
ll query(int u, int l, int r) {
if (l > tr[u].r || r < tr[u].l) return 0;
if (l <= tr[u].l && tr[u].r <= r) {
return tr[u].sum;
}
pushdown(u);
return query(lc, l, r) + query(rc, l, r);
}
int main() {
scanf("%d%d", &n, &m);
build(1, 1, n);
while (m--) {
int op;
scanf("%d", &op);
if (op == 1) {
int s, l, r;
scanf("%d%d%d", &s, &l, &r);
change(1, l, r, s, s);
} else {
int l, r;
scanf("%d%d", &l, &r);
printf("%lld\n", query(1, l, r));
}
}
return 0;
return 0;
}
详细
小提示:点击横条可展开更详细的信息
Test #1:
score: 0
Wrong Answer
time: 18ms
memory: 2216kb
input:
10000 10000 2 7160 9968 1 -473 6964 8476 1 -153 5216 7023 2 6352 6868 1 -323 2338 2855 1 415 8414 88...
output:
0 3390989719 4402519964 10791753 -8639331948 -7199702699 -10821147060 -6471580070 -3721957859 -27214...
result:
wrong answer 2nd lines differ - expected: '-110345895', found: '3390989719'
Test #2:
score: 0
Wrong Answer
time: 13ms
memory: 2220kb
input:
10000 10000 1 326 2291 8264 2 2344 3512 1 146 4506 4804 1 342 1373 4495 1 -267 929 3525 1 444 3384 8...
output:
2939743300 -12232327350 0 -6552231440 -5349658329 -1991678858 -19273221390 -11608391064 867235226 52...
result:
wrong answer 1st lines differ - expected: '243137972', found: '2939743300'
Test #3:
score: 0
Runtime Error
input:
666666 10000 1 92 555251 586462 1 393 28541 523118 1 448 17256 369367 1 -28 89257 596132 1 -338 3136...
output:
result:
Test #4:
score: 0
Runtime Error
input:
666666 50000 1 -249 309981 333889 1 477 309512 463171 1 0 71655 592642 1 45 191249 527454 1 55 38872...
output:
result:
Test #5:
score: 0
Runtime Error
input:
666666 100000 1 -183 598736 630118 1 -337 605875 639236 1 -62 265069 340682 1 -96 370300 571646 1 -1...
output:
result:
Test #6:
score: 0
Runtime Error
input:
666666 100000 2 121929 379928 2 34550 66844 1 96 338911 637923 2 161666 370147 1 -282 313713 463127 ...
output:
result:
Test #7:
score: 0
Runtime Error
input:
750000 100000 1 -318 454211 721481 2 239247 294171 2 52513 339575 2 424462 638364 2 683282 740790 1 ...
output:
result:
Test #8:
score: 0
Runtime Error
input:
1000000 100000 1 -108 318728 708230 1 -242 8738 411540 1 -119 458000 972357 2 368015 850304 1 -182 1...
output:
result:
Test #9:
score: 0
Runtime Error
input:
1000000 100000 2 347033 984386 2 277881 323793 1 431 735974 973576 2 782909 863840 1 -22 379088 6406...
output:
result:
Test #10:
score: 0
Runtime Error
input:
1000000 100000 1 -238 406279 814973 1 -425 637451 721356 1 237 340114 658854 2 279214 591961 2 17862...