QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#34170 | #4236. Triangular Logs | Heltion# | WA | 411ms | 34612kb | C++20 | 2.1kb | 2022-06-05 20:41:29 | 2022-06-05 20:41:32 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define ls (v << 1)
#define rs (ls | 1)
#define tm ((tl + tr) >> 1)
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n, q;
cin >> n >> q;
vector<tuple<int, int, int>> vt(n);
vector<int> dx;
for (auto& [x, y, h] : vt) {
cin >> x >> y >> h;
dx.push_back(x);
}
ranges::sort(dx);
dx.erase(unique(dx.begin(), dx.end()), dx.end());
int m = dx.size();
vector<vector<pair<int, int>>> nodes(m << 2);
function<void(int, int, int, int, int, int)> add = [&](int v, int tl, int tr, int x, int y, int h) {
nodes[v].emplace_back(y, h);
if (tl == tr) return;
if (x <= tm) add(ls, tl, tm, x, y, h);
else add (rs, tm + 1, tr, x, y, h);
};
for (auto [x, y, h] : vt) {
x = ranges::lower_bound(dx, x) - dx.begin();
add(1, 0, m - 1, x, y, h);
}
for (auto& v : nodes) ranges::sort(v);
for (int i = 0; i < q; i += 1) {
int x1, x2, y1, y2;
cin >> x1 >> y1 >> x2 >> y2;
x1 = ranges::lower_bound(dx, x1) - dx.begin();
x2 = ranges::upper_bound(dx, x2) - dx.begin();
if (x2 <= x1) {
cout << "0\n";
continue;
}
x2 -= 1;
vector<int> vh;
function<void(int, int, int)> DFS = [&](int v, int tl, int tr) {
if (vh.size() >= 32) return;
if (tl >= x1 and tr <= x2) {
auto it = ranges::lower_bound(nodes[v], make_pair(y1, 0));
while (it != nodes[v].end() and it->first <= y2 and vh.size() < 32) {
vh.push_back(it->second);
it = next(it);
}
return;
}
if (x1 <= tm) DFS(ls, tl, tm);
if (x2 > tm) DFS(rs, tm + 1, tr);
};
DFS(1, 0, m - 1);
ranges::sort(vh);
int ok = 0;
for (int i = 0; i + 2 < vh.size(); i += 1)
if (vh[i] + vh[i + 1] > vh[i + 2])
ok = 1;
cout << ok << "\n";
}
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 2ms
memory: 3568kb
input:
9 5 1 3 3 2 3 1 3 3 4 1 2 1 2 2 5 3 2 9 1 1 2 2 1 6 3 1 5 1 1 1 2 1 1 2 2 1 1 1 3 1 2 3 2 1 1 3 3
output:
0 1 0 0 1
result:
ok 5 lines
Test #2:
score: 0
Accepted
time: 1ms
memory: 3680kb
input:
481 1 8 6788 8975 24 6552 2668 26 7948 4730 40 531 9805 110 1914 1916 164 7073 3371 165 6293 7756 170 9946 2003 179 9654 1700 215 6447 2229 221 3149 3030 242 1999 6843 242 5764 3163 249 3716 8634 250 6801 9317 260 2741 4273 282 5436 4836 284 3951 6483 288 4812 76 375 9004 5492 380 5627 5929 391 6385...
output:
1
result:
ok single line: '1'
Test #3:
score: 0
Accepted
time: 2ms
memory: 3660kb
input:
378 1 62730 50925 80731 92666 77280 61521 29236 67032 7889 35986 96802 8763 13313 49918 83582 51842 66775 47834 2286 12925 41106 39790 6698 15243 65145 56379 68496 35570 809 525 39834 16723 48002 77230 16273 16032 52615 7621 77300 92267 82517 39917 13170 89084 77751 45638 23868 49631 7758 71381 5191...
output:
1
result:
ok single line: '1'
Test #4:
score: 0
Accepted
time: 249ms
memory: 26448kb
input:
100000 100000 299999993 206450345 26023928 334281171 300000008 18107965 318653732 299999990 82338399 299999997 393028366 37212808 299999992 208114125 82126189 300000002 303613195 34463905 270033576 299999993 49200970 300000003 249755524 5829381 300000003 367329175 12867359 300000009 337452692 131045...
output:
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ...
result:
ok 100000 lines
Test #5:
score: 0
Accepted
time: 282ms
memory: 26476kb
input:
100000 100000 299999990 299999990 40343876 299999990 299999991 75128878 299999990 299999992 54630219 299999990 299999993 2733654 299999990 299999994 46236519 299999990 299999995 98430004 299999990 299999996 48355189 299999990 299999997 85287882 299999990 299999998 83938086 299999990 299999999 739070...
output:
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ...
result:
ok 100000 lines
Test #6:
score: 0
Accepted
time: 271ms
memory: 34612kb
input:
100000 100000 586649484 999402721 770254678 406977522 613559 332964690 987164 445493717 518079399 249557488 999424331 597100212 143514230 999205612 56986976 933588533 509797 769263555 696911 930171165 201130067 833170 541105172 912457971 145501 423684829 612968794 999276416 167526939 136454621 70428...
output:
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ...
result:
ok 100000 lines
Test #7:
score: 0
Accepted
time: 294ms
memory: 34576kb
input:
100000 100000 341071 873501571 1101 59980263 526804 9 297715277 999186682 197674 709891830 999005915 346 999712634 250379232 3158 999959502 879534904 11273 253455643 999864444 49222 427866822 999577133 210191465 729566332 999548170 14 657471525 144302 846059 319542083 999756032 6275 219750473 765955...
output:
0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 1 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 ...
result:
ok 100000 lines
Test #8:
score: 0
Accepted
time: 411ms
memory: 28444kb
input:
100000 100000 330451877 499036874 19421 148915905 333179772 5692 556747855 500052531 51199 580265032 499999972 188350435 380806313 500000128 65 500046272 499999847 2336904 496578778 500015254 22900850 499999993 473970765 17403806 499999989 499163205 2 499999946 499999562 19056 671553596 327120722 53...
output:
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 ...
result:
ok 100000 lines
Test #9:
score: 0
Accepted
time: 2ms
memory: 3552kb
input:
44 1 1 1 1 2 2 1 3 3 2 4 4 3 5 5 5 6 6 8 7 7 13 8 8 21 9 9 34 10 10 55 11 11 89 12 12 144 13 13 233 14 14 377 15 15 610 16 16 987 17 17 1597 18 18 2584 19 19 4181 20 20 6765 21 21 10946 22 22 17711 23 23 28657 24 24 46368 25 25 75025 26 26 121393 27 27 196418 28 28 317811 29 29 514229 30 30 832040 3...
output:
0
result:
ok single line: '0'
Test #10:
score: -100
Wrong Answer
time: 2ms
memory: 3708kb
input:
45 1 1 1 1 2 2 1 3 3 2 4 4 3 5 5 5 6 6 8 7 7 13 8 8 21 9 9 34 10 10 55 11 11 89 12 12 144 13 13 233 14 14 377 15 15 610 16 16 987 17 17 1597 18 18 2584 19 19 4181 20 20 6765 21 21 10946 22 22 17711 23 23 28657 24 24 46368 25 25 75025 26 26 121393 27 27 196418 28 28 317811 29 29 514229 30 30 832040 3...
output:
0
result:
wrong answer 1st lines differ - expected: '1', found: '0'