QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#723390 | #3028. Frogs | Markadiusz# | AC ✓ | 564ms | 29412kb | C++23 | 1.6kb | 2024-11-07 22:03:14 | 2024-11-07 22:03:15 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
using LL=long long;
#define FOR(i,l,r) for(int i=(l);i<=(r);++i)
#define REP(i,n) FOR(i,0,(n)-1)
#define ssize(x) int(x.size())
#ifdef DEBUG
auto&operator<<(auto&o,pair<auto,auto>p){return o<<"("<<p.first<<", "<<p.second<<")";}
auto operator<<(auto&o,auto x)->decltype(x.end(),o){o<<"{";int i=0;for(auto e:x)o<<","+!i++<<e;return o<<"}";}
#define debug(X...) cerr<<"["#X"]: ",[](auto...$){((cerr<<$<<"; "),...)<<endl;}(X)
#else
#define debug(...) {}
#endif
vector<vector<int>> tree;
int sz;
void add(int w, int a, int b, int l, int r, int val) {
if (a > r or b < l)
return;
if (a >= l and b <= r) {
tree[w].emplace_back(val);
if (ssize(tree[w]) > 3) {
sort(tree[w].rbegin(), tree[w].rend());
tree[w].pop_back();
}
return;
}
const int mid = (a + b) / 2;
add(w * 2, a, mid, l, r, val);
add(w * 2 + 1, mid + 1, b, l, r, val);
}
int que(int pos) {
pos += sz;
vector<int> ret;
while (pos) {
ret.insert(ret.end(), tree[pos].begin(), tree[pos].end());
pos /= 2;
}
sort(ret.rbegin(), ret.rend());
ret.resize(3);
int ans = accumulate(ret.begin(), ret.end(), 0);
return ans;
}
int main() {
cin.tie(0)->sync_with_stdio(0);
int t;
cin >> t;
REP(tt, t) {
tree.clear();
int n;
cin >> n;
sz = 1;
while (sz < n)
sz *= 2;
tree.resize(2 * sz);
vector<int> r(n), s(n);
REP(i, n)
cin >> r[i] >> s[i];
debug(n, r, s);
REP(i, n) {
int L = max(0, i - r[i]);
int R = min(n - 1, i + r[i]);
add(1, 0, sz - 1, L, R, s[i]);
}
int answer = 0;
REP(i, n) {
answer = max(answer, que(i));
}
cout << answer << '\n';
}
}
详细
Test #1:
score: 100
Accepted
time: 484ms
memory: 29412kb
input:
29 24946 1 145304 3 52200 2 96731 2 96731 34 5867 5 39209 1 124746 1 195359 1 140091 1 195359 1 140091 2 94760 7 26440 14 14264 34 5735 2 67479 1 116444 4 43152 2 70412 3 54405 3 54405 1 106845 4 49540 1 106845 1 118592 27 7212 1 118592 2 74860 243 821 6 28584 2 74860 1 103054 6 29393 3 55906 2 7299...
output:
596106 213676 571306 288754 4 108 4 8 599840 27 62 539982 46 235651 317587 5 258922 449979 25 165256 12 599968 11 3 5 413196 4 599639 60
result:
ok 29 lines
Test #2:
score: 0
Accepted
time: 564ms
memory: 26568kb
input:
30 3758 62 1 107 1 134 3 133 1 92 1 65 1 276 1 316 1 111 1 274 1 374 2 100 2 217 1 40 1 127 1 123 1 270 2 18 1 26 1 233 2 278 3 152 2 157 2 9 2 61 1 29 1 374 1 45 1 156 1 231 1 303 1 405 1 330 1 407 2 375 3 111 1 269 1 115 1 17 1 56 1 363 1 255 2 176 1 66 3 132 1 35 2 391 1 371 2 260 1 175 1 369 4 7...
output:
15 111 570316 6 145 598141 9790 379220 6 302651 8977 7187 574039 276501 528609 1189 6 416728 20557 9 20919 9 524338 266777 500921 559918 62 10635 3609 521671
result:
ok 30 lines
Test #3:
score: 0
Accepted
time: 419ms
memory: 25512kb
input:
30 16 3 9 7 18 3 20 8 2 5 9 6 1 2 19 2 6 3 22 2 8 7 11 3 9 1 12 2 6 8 11 7 7 16 13 2 2 2 13 2 12 4 3 4 2 3 2 3 1 3 1 3 11 1 1 3 4 3 11 4 7 2 7 5 7 4 166437 1 182681 1 170305 1 130895 2 81506 1 121104 2 99552 1 134739 1 180951 2 82208 2 86256 1 189082 3 53511 1 172928 6 32142 2 88879 1 136048 1 13239...
output:
61 13 589248 5 565958 296385 3 42 83 419938 25 541769 569373 12 385323 3 24 410656 579080 4 63 15 317025 6 246039 310300 133 239965 335677 12
result:
ok 30 lines