QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#865377 | #8229. 栈 | thangthang | 16 | 226ms | 24352kb | C++20 | 2.6kb | 2025-01-21 17:18:00 | 2025-01-21 17:18:01 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 5;
struct Info{
long long add, del, S;
} E = {0, 0, 0}, p[N << 2], now;
int n, m, q;
vector <pair <int, Info>> event[N];
vector <tuple <int, long long, long long, int>> query[N];
long long res[N];
Info solve(int s, int l, int r, long long D){
if (l == r){
if (p[s].add <= D) return {0, D - p[s].add + p[s].del, 0};
return {p[s].add - D, 0, p[s].S / p[s].add * (p[s].add - D)};
}
int mid = l + r >> 1;
if (p[s << 1 | 1].add <= D) return solve(s << 1, l, mid, D - p[s << 1 | 1].add + p[s << 1 | 1].del);
Info res = solve(s << 1 | 1, mid + 1, r, D);
return {p[s].add + res.add - p[s << 1 | 1].add, p[s].del, p[s].S + res.S - p[s << 1 | 1].S};
}
void upd(int s, int l, int r){
Info t = solve(s, l, r, now.del);
now = {t.add + now.add, t.del, t.S + now.S};
}
void modify(int s, int l, int r, int u, Info v){
if (l == r){
p[s] = v;
return;
}
int mid = l + r >> 1;
if (mid >= u) modify(s << 1, l, mid, u, v);
else modify(s << 1 | 1, mid + 1, r, u, v);
now = p[s << 1 | 1]; upd(s << 1, l, mid); p[s] = now;
}
void Get(int s, int l, int r, int v){
if (l > v) return;
if (r <= v){
upd(s, l, r);
return;
}
int mid = l + r >> 1;
Get(s << 1 | 1, mid + 1, r, v);
Get(s << 1, l, mid, v);
}
int get(int x, long long y){
now = E;
Get(1, 1, m, x);
now = {0, now.add - min(y, now.add), 0};
Get(1, 1, m, x);
return now.S;
}
void process(){
cin >> n >> m;
for (int i = 1; i <= m; ++ i){
int op; cin >> op;
if (op == 1){
int l, r, x, y;
cin >> l >> r >> x >> y;
event[l].push_back({i, {x, 0, 1ll * x * y}});
event[r + 1].push_back({i, E});
}
else if (op == 2){
int l, r; long long w;
cin >> l >> r >> w;
event[l].push_back({i, {0, w, 0}});
event[r + 1].push_back({i, E});
}
else {
int id;
long long l, r;
cin >> id >> l >> r;
query[id].push_back({i, l, r, ++ q});
}
}
for (int i = 1; i <= n; ++ i){
for (auto [x, y] : event[i]) modify(1, 1, m, x, y);
for (auto [x, l, r, id] : query[i])
res[id] = get(x, r) - get(x, l - 1);
}
for (int i = 1; i <= q; ++ i)
cout << res[i] << "\n";
}
int main(){
ios_base::sync_with_stdio(0);
cin.tie(0); cout.tie(0);
process();
return 0;
}
详细
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 0
Wrong Answer
time: 4ms
memory: 6208kb
input:
4907 4910 2 763 3330 1 3 307 1 1 1 2262 3430 22699 89397 1 1915 4000 51541 67587 2 212 2990 9763 2 1086 2162 1 2 1813 4496 16760 1 51 2796 68005 99390 1 1267 1519 74236 66178 3 1768 23808 54314 2 900 4122 27758 3 3287 17350 28989 2 3277 4024 3633 2 444 4866 1 2 353 4219 1061 1 987 3141 99906 17320 2...
output:
0 -1262876566 903396180 471569175 200648623 98486697 647114751 123945 50793012 61782451 0 0 0 762429740 321140700 871619914 536311874 1066127596 0 1792521566 -1949415844 -1879591516 249435711 225987900 955820742 1145132507 140071334 0 118545795 -1208561827 1351131975 84280112 1232466642 697999479 -6...
result:
wrong answer 2nd numbers differ - expected: '3032090730', found: '-1262876566'
Subtask #2:
score: 0
Wrong Answer
Test #6:
score: 0
Wrong Answer
time: 226ms
memory: 21808kb
input:
99999 99998 1 5026 18575 27178 90423 3 30623 1 1 3 76936 1 1 1 77021 95683 84664 24734 1 46085 74886 40512 11266 3 5048 8594 22468 1 53318 77721 97151 70784 1 70645 91192 37556 13013 1 56752 56940 91812 62887 1 7928 34576 87339 69404 3 74875 32807 100970 3 22338 17221 25771 3 21421 20602 57957 3 717...
output:
0 0 1254619125 71307572 593473604 -1702311472 -636991744 1357546537 110091352 1226646296 1989326852 763582808 -384615921 1659086055 -1282368355 -1389253895 -1052166120 201439520 -1214406757 427856928 -1165979320 899316516 280345290 988382364 456921733 -1487142397 -1845283712 1580309805 -532699082 15...
result:
wrong answer 4th numbers differ - expected: '4366274868', found: '71307572'
Subtask #3:
score: 16
Accepted
Test #12:
score: 16
Accepted
time: 153ms
memory: 22036kb
input:
100000 99993 1 47773 70467 16065 1 2 52349 78446 2304 3 40821 1 1 1 40216 93069 78144 1 1 41089 43671 76025 1 2 35263 68629 31066 3 79881 13534 57327 3 5556 1 1 2 21962 38192 1 1 664 58116 9417 1 3 28089 6039 7989 2 88500 90302 9946 3 63215 49410 60770 2 11069 89527 57581 2 70303 97603 12363 1 3420 ...
output:
0 43794 0 1951 11361 129 898 29245 7969 1947 34972 16405 59952 123666 24537 68209 34537 0 32225 37527 0 31810 16824 96178 14285 300941 57614 1602 129470 61935 4068 114182 17609 152949 26099 179359 250368 4796 183349 125791 17414 61871 42058 0 2698 183297 23029 54464 0 26259 204595 35604 0 0 18437 29...
result:
ok 33281 numbers
Test #13:
score: 16
Accepted
time: 152ms
memory: 22580kb
input:
100000 99999 3 11279 1 1 1 21196 82827 47041 1 2 58608 97529 1 2 22065 32528 37154 1 2138 16260 96858 1 1 25755 42875 82334 1 1 31799 48594 28327 1 3 58271 16371 33060 1 9407 50398 53680 1 2 40505 54132 176725 2 4626 22919 41250 2 28476 63110 133245 2 501 87564 1 2 5927 27401 96494 2 27254 64078 1 2...
output:
0 16690 27551 1442 4671 0 35160 4953 1559 3430 1768 0 0 11628 0 0 2495 13673 0 0 162093 135864 330 17312 0 29074 0 0 0 33641 51926 7051 0 0 42277 0 44110 543 12418 51322 9338 89794 9387 44052 43969 170272 42203 209676 5275 15969 11537 29757 26609 8288 33600 0 21384 48804 75598 11624 67508 10170 1751...
result:
ok 33467 numbers
Test #14:
score: 16
Accepted
time: 181ms
memory: 22152kb
input:
99993 99998 3 67041 1 1 3 6929 1 1 2 17524 32038 1 2 61604 73005 1 3 89616 1 1 2 40031 62338 1 3 58255 1 1 1 13009 67563 20939 1 1 73959 97229 47418 1 2 60834 61638 3740 2 29078 66369 1909 3 20355 4984 7284 2 75885 86625 3998 1 58692 90189 3242 1 3 99600 1 1 1 4102 8018 16478 1 3 53676 3918 8517 3 6...
output:
0 0 0 0 2301 0 4600 1472 56471 13213 0 143912 24988 0 59240 0 0 65385 5137 154745 70944 42704 209563 9676 121308 24627 52979 49278 37462 16444 0 1611 409040 392695 111628 265718 65783 55560 11142 45479 32621 118811 0 27594 239805 284844 19955 220309 8044 161759 1982 53200 41530 102413 43466 28624 17...
result:
ok 33389 numbers
Test #15:
score: 16
Accepted
time: 180ms
memory: 21904kb
input:
99991 99996 1 47657 83825 20467 1 2 18475 94316 1 1 45137 56194 42134 1 2 62287 64784 3656 1 34371 82222 66403 1 2 26982 76957 4461 2 1186 62584 1 2 63744 85641 5313 1 20658 59024 63800 1 2 51424 82606 5804 2 90768 91321 1 3 15951 1 1 2 51955 91548 1298 3 37870 8860 39509 3 8317 1 1 3 308 1 1 1 1977...
output:
0 30650 0 0 0 0 0 52497 2540 51822 0 22469 45077 10570 146261 11438 80060 21311 114935 197491 113332 156089 207620 36833 104730 21761 58044 72459 72699 105703 297859 98381 351013 75662 42544 50509 161825 375089 22703 209315 121760 4317 496943 121741 116864 11213 87742 871 452690 54302 100601 39830 2...
result:
ok 33262 numbers
Test #16:
score: 16
Accepted
time: 203ms
memory: 24352kb
input:
99997 99999 2 53252 91242 1 1 57337 88934 37260 1 1 16834 34642 93492 1 2 81166 94101 6093 1 46770 56947 41803 1 2 70882 88729 2179 2 55489 59818 1 1 29212 60579 61103 1 3 37904 1447 28743 1 68609 95313 51191 1 1 41758 51157 38733 1 3 57276 44404 49850 1 53448 66120 27464 1 1 64716 86889 8186 1 1 30...
output:
27297 5447 87454 7764 0 36668 9059 202784 226798 35791 44217 20176 425699 841344 314555 628121 279373 862035 1237442 638303 225509 1013325 143603 280017 469785 168019 102756 1008786 266597 5507 31097 1524290 288879 523157 706592 434088 1052960 282317 254606 633715 493060 281268 273353 139218 259977 ...
result:
ok 16863 numbers
Subtask #4:
score: 0
Wrong Answer
Test #17:
score: 0
Wrong Answer
time: 153ms
memory: 21940kb
input:
99999 99996 3 77889 1 10000000000 1 6316 86327 89644 386 3 9260 1 10000000000 2 2603 47234 69717 2 20260 73011 19290 2 62477 81233 26127 1 50140 68508 37004 98794 2 14449 22788 16063 1 43860 84932 50375 21777 1 67345 94584 28202 66610 2 661 68654 1 1 14411 94422 82738 61196 1 16563 94416 4920 38408 ...
output:
0 34602584 0 0 1969835807 1363823412 0 1902514434 1902514434 -2147413412 1902514434 -1385494090 0 -102520639 -1382390999 257019257 0 2056976794 1480215725 363222594 1995572111 -2101616414 0 -1746673276 1213968395 250667843 0 1296321611 -855884614 483916682 -32337344 201376523 2126317199 -1553097065 ...
result:
wrong answer 5th numbers differ - expected: '27739639583', found: '1969835807'
Subtask #5:
score: 0
Skipped
Dependency #1:
0%