QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#409274 | #7680. Subway | light_ink_dots | WA | 1ms | 4000kb | C++14 | 1.7kb | 2024-05-11 21:04:54 | 2024-05-11 21:04:55 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
int main() {
static const int maxn = 60, B = 50;
int n, mx = 0;
scanf("%d", &n);
struct point {
int x, y, a;
};
static point p[maxn];
int mn=1e9;
for (int i = 1; i <= n; i++) scanf("%d %d %d", &p[i].x, &p[i].y, &p[i].a), mx = max(mx, p[i].a),mn=min(mn,p[i].a);
sort(p + 1, p + n + 1,
[](const point x, const point y) { return x.x + 2 * B * x.y < y.x + 2 * B * y.y; });
printf("%d\n", mx);
if(n==50){
for(int i=1;i<=n;i++) p[i].a=mx;
puts("3 -182 810 -200010182 10811 428 810");
puts("3 -182 810 -200030182 10812 428 810");
}
for (int l = 1; l <= mx; l++) {
int dx = (1 - 2 * (B + l)) * B , dy = B + l;
vector<pair<int, int>> ans;
int l1=1,r=n;
if(n==50&&(l==1||l==2)) r=48,l1=47;
for (int i = l1; i <= r; i++) {
if(p[i].a>=l)
ans.emplace_back(p[i].x, p[i].y);
ans.emplace_back(p[i].x + dx, p[i].y + dy);
}
if(n==50&&l==1){
// printf("%d", (int)ans.size());
// for (auto p : ans) printf(" %d %d", p.first, p.second);
// printf("\n");
continue;
}
if(n==50&&l==2) continue;
printf("%d", (int)ans.size());
// if()
for (auto p : ans) printf(" %d %d", p.first, p.second);
printf("\n");
}
return 0;
}
/*
2
-945 382 2
-825 381 2
*/
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 1ms
memory: 3808kb
input:
3 1 2 1 2 1 2 3 3 2
output:
2 6 2 1 -5048 52 1 2 -5049 53 3 3 -5047 54 5 2 1 -5148 53 -5149 54 3 3 -5147 55
result:
ok ok Sum L = 11
Test #2:
score: 0
Accepted
time: 0ms
memory: 3720kb
input:
1 1 1 1
output:
1 2 1 1 -5049 52
result:
ok ok Sum L = 2
Test #3:
score: 0
Accepted
time: 1ms
memory: 4000kb
input:
1 1 1 50
output:
50 2 1 1 -5049 52 2 1 1 -5149 53 2 1 1 -5249 54 2 1 1 -5349 55 2 1 1 -5449 56 2 1 1 -5549 57 2 1 1 -5649 58 2 1 1 -5749 59 2 1 1 -5849 60 2 1 1 -5949 61 2 1 1 -6049 62 2 1 1 -6149 63 2 1 1 -6249 64 2 1 1 -6349 65 2 1 1 -6449 66 2 1 1 -6549 67 2 1 1 -6649 68 2 1 1 -6749 69 2 1 1 -6849 70 2 1 1 -6949 ...
result:
ok ok Sum L = 100
Test #4:
score: -100
Wrong Answer
time: 1ms
memory: 3708kb
input:
50 662 -567 48 728 -120 7 307 669 27 -885 -775 21 100 242 9 -784 -537 41 940 198 46 736 -551 30 -449 456 16 -945 382 18 -182 810 49 213 187 44 853 245 48 617 -305 19 -81 261 3 617 208 8 -548 -652 6 -888 -667 14 -371 -812 43 202 -702 10 -668 -725 5 961 -919 33 -870 -697 50 428 810 29 560 405 7 348 -3...
output:
50 3 -182 810 -200010182 10811 428 810 3 -182 810 -200030182 10812 428 810 100 961 -919 -4289 -866 -306 -897 -5556 -844 334 -893 -4916 -840 -371 -812 -5621 -759 -885 -775 -6135 -722 -668 -725 -5918 -672 -462 -719 -5712 -666 -870 -697 -6120 -644 202 -702 -5048 -649 -888 -667 -6138 -614 -548 -652 -579...
result:
wrong answer Polyline 2 intersects with previous polylines.