| Task: | Maalaus |
| Sender: | NicholasAhman |
| Submission time: | 2025-11-03 21:51:01 +0200 |
| Language: | C++ (C++17) |
| Status: | READY |
| Result: | 0 |
| group | verdict | score |
|---|---|---|
| #1 | WRONG ANSWER | 0 |
| #2 | TIME LIMIT EXCEEDED | 0 |
| #3 | WRONG ANSWER | 0 |
| #4 | WRONG ANSWER | 0 |
| test | verdict | time | group | |
|---|---|---|---|---|
| #1 | ACCEPTED | 0.00 s | 1, 3, 4 | details |
| #2 | ACCEPTED | 0.00 s | 3, 4 | details |
| #3 | WRONG ANSWER | 0.00 s | 1, 3, 4 | details |
| #4 | TIME LIMIT EXCEEDED | -- | 2, 4 | details |
| #5 | TIME LIMIT EXCEEDED | -- | 2, 4 | details |
| #6 | WRONG ANSWER | 0.17 s | 3, 4 | details |
| #7 | WRONG ANSWER | 0.18 s | 3, 4 | details |
| #8 | TIME LIMIT EXCEEDED | -- | 4 | details |
| #9 | TIME LIMIT EXCEEDED | -- | 4 | details |
| #10 | WRONG ANSWER | 0.00 s | 1, 3, 4 | details |
| #11 | WRONG ANSWER | 0.00 s | 1, 3, 4 | details |
| #12 | TIME LIMIT EXCEEDED | -- | 2, 4 | details |
| #13 | TIME LIMIT EXCEEDED | -- | 2, 4 | details |
| #14 | TIME LIMIT EXCEEDED | -- | 4 | details |
| #15 | TIME LIMIT EXCEEDED | -- | 4 | details |
| #16 | TIME LIMIT EXCEEDED | -- | 4 | details |
| #17 | TIME LIMIT EXCEEDED | -- | 4 | details |
Compiler report
input/code.cpp: In function 'void draw_line(int, size_t, int)':
input/code.cpp:47:39: warning: comparison of integer expressions of different signedness: 'size_t' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
47 | for (size_t i = ops.size() - 1; i != -1; i--) {
| ~~^~~~~
input/code.cpp: In function 'int main()':
input/code.cpp:141:18: warning: format '%u' expects argument of type 'unsigned int', but argument 2 has type 'uint64_t' {aka 'long unsigned int'} [-Wformat=]
141 | printf("%u ", colors[i]);
| ~^ ~~~~~~~~~
| | |
| unsigned int uint64_t {aka long unsigned int}
| %luCode
#include <cstdlib>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <stdint.h>
#include <unordered_map>
#include <unordered_set>
#include <vector>
uint64_t *colors;
size_t width;
size_t height;
size_t color_count;
struct Drawing {
int rc;
size_t n;
int color;
};
struct Point {
size_t x;
size_t y;
};
std::vector<Drawing> ops;
Point intersection(int rc1, size_t n1, int rc2, size_t n2) {
if (rc1 == 'C') {
return { .x = n1, .y = n2};
} else {
return { .x = n2, .y = n1};
}
}
void draw_line(int rc, size_t n, int color) {
colors[color] += rc == 'R' ? width : height;
if (ops.size() == 0) {
ops.push_back({rc, n, color});
return;
}
std::unordered_map<size_t, Point> intersections;
for (size_t i = ops.size() - 1; i != -1; i--) {
if (ops[i].rc != rc) {
Point is = intersection(rc, n, ops[i].rc, ops[i].n);
if (intersections.count(is.x + width * is.y) == 0) {
colors[ops[i].color]--;
intersections.insert({is.x + width * is.y, is});
}
} else {
if (n != ops[i].n) {
continue;
}
std::unordered_set<size_t> is2;
size_t covered = rc == 'R' ? width : height;
for (size_t j = i + 1; j < ops.size(); j++) {
if (ops[j].rc != ops[i].rc) {
Point is = intersection(ops[i].rc, ops[i].n, ops[j].rc, ops[j].n);
if (is2.count(is.x + width * is.y) == 0) {
covered--;
is2.insert(is.x + width * is.y);
}
} else {
if (n != ops[j].n) {
continue;
}
covered = 0;
break;
}
}
colors[ops[i].color] -= covered;
}
}
ops.push_back({rc, n, color});
}
int main(void) {
char *input = (char *)malloc(1024*1024*8);
const size_t len = read(0, input, 1024*1024*8);
size_t idx = 0;
size_t next_space = strchr(input, ' ') - input;
input[next_space] = '\0';
height = atoi(input);
idx += next_space + 1;
next_space = strchr((input + idx), ' ') - (input + idx);
(input + idx)[next_space] = '\0';
width = atoi((input + idx));
idx += next_space + 1;
next_space = strchr((input + idx), ' ') - (input + idx);
(input + idx)[next_space] = '\0';
color_count = atoi((input + idx));
idx += next_space + 1;
next_space = strchr((input + idx), '\n') - (input + idx);
(input + idx)[next_space] = '\0';
size_t operations = atoi((input + idx));
idx += next_space + 1;
colors = (uint64_t *)malloc((color_count + 1) * sizeof(uint64_t));
ops.reserve(operations);
for (size_t i = 0; i < color_count + 1; i++) {
colors[i] = 0;
}
for (size_t i = 0; i < operations; i++) {
int rc = (input + idx)[0];
idx += 2;
next_space = strchr((input + idx), ' ') - (input + idx);
(input + idx)[next_space] = '\0';
size_t n = atoi((input + idx));
idx += next_space + 1;
if (i == operations - 1) {
next_space = len - ((input + idx) - input) - 1;
} else {
next_space = strchr((input + idx), '\n') - (input + idx);
}
(input + idx)[next_space] = '\0';
size_t color = atoi((input + idx));
idx += next_space + 1;
draw_line(rc, n, color);
}
for (size_t i = 1; i < color_count + 1; i++) {
printf("%u ", colors[i]);
}
free(input);
free(colors);
}
Test details
Test 1 (public)
Group: 1, 3, 4
Verdict: ACCEPTED
| input |
|---|
| 3 4 4 4 R 1 1 C 3 4 R 2 2 R 1 1 |
| correct output |
|---|
| 4 4 0 1 |
| user output |
|---|
| 4 4 0 1 |
Test 2 (public)
Group: 3, 4
Verdict: ACCEPTED
| input |
|---|
| 1000000000 1000000000 5 10 C 70724881 4 C 290904744 1 C 569311326 5 R 896293092 1 ... |
| correct output |
|---|
| 3999999991 1999999998 19999999... |
| user output |
|---|
| 3999999991 1999999998 19999999... |
Test 3
Group: 1, 3, 4
Verdict: WRONG ANSWER
| input |
|---|
| 10 10 10 10 R 10 8 C 1 2 R 10 2 R 1 4 ... |
| correct output |
|---|
| 0 13 0 8 7 20 0 0 10 7 |
| user output |
|---|
| 0 12 0 8 7 20 0 0 10 7 |
Feedback: Incorrect character on line 1 col 4: expected "13", got "12"
Test 4
Group: 2, 4
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 1000000000 1000000000 1 200000 R 185082082 1 C 549662476 1 R 484749097 1 R 330334821 1 ... |
| correct output |
|---|
| 199984000629575 |
| user output |
|---|
| (empty) |
Test 5
Group: 2, 4
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 1000000000 1000000000 1 200000 C 354072394 1 C 221236382 1 C 63527838 1 C 538599654 1 ... |
| correct output |
|---|
| 126261014543986 |
| user output |
|---|
| (empty) |
Test 6
Group: 3, 4
Verdict: WRONG ANSWER
| input |
|---|
| 1000000000 1000000000 2000 200... |
| correct output |
|---|
| 999999400 2999997760 999999118... |
| user output |
|---|
| 999999400 2999997760 999999118... |
Feedback: Incorrect character on line 1 col 1251: expected "4999997617", got "705030321"
Test 7
Group: 3, 4
Verdict: WRONG ANSWER
| input |
|---|
| 1000000000 1000000000 2000 200... |
| correct output |
|---|
| 999999481 0 999999445 0 0 0 0 ... |
| user output |
|---|
| 999999222 4294967200 999999139... |
Feedback: Incorrect character on line 1 col 7: expected "999999481", got "999999222"
Test 8
Group: 4
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 1000000000 1000000000 200000 2... |
| correct output |
|---|
| 0 0 999997829 0 1999872519 199... |
| user output |
|---|
| (empty) |
Test 9
Group: 4
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 1000000000 1000000000 200000 2... |
| correct output |
|---|
| 999986843 0 0 999966411 999971... |
| user output |
|---|
| (empty) |
Test 10
Group: 1, 3, 4
Verdict: WRONG ANSWER
| input |
|---|
| 1 10 10 10 C 1 10 R 1 4 C 9 3 R 1 7 ... |
| correct output |
|---|
| 1 0 0 0 0 0 0 9 0 0 |
| user output |
|---|
| 1 0 4294967292 0 0 0 0 9 0 429... |
Feedback: Incorrect character on line 1 col 5: expected "0", got "4294967292"
Test 11
Group: 1, 3, 4
Verdict: WRONG ANSWER
| input |
|---|
| 10 1 10 10 R 4 6 R 5 1 R 4 2 R 3 9 ... |
| correct output |
|---|
| 0 0 0 0 0 0 0 10 0 0 |
| user output |
|---|
| 0 4294967294 4294967295 429496... |
Feedback: Incorrect character on line 1 col 3: expected "0", got "4294967294"
Test 12
Group: 2, 4
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 1 1000000000 1 200000 C 298761159 1 R 1 1 C 831911362 1 C 25171734 1 ... |
| correct output |
|---|
| 1000000000 |
| user output |
|---|
| (empty) |
Test 13
Group: 2, 4
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 1000000000 1 1 200000 R 68306849 1 C 1 1 C 1 1 R 485427101 1 ... |
| correct output |
|---|
| 1000000000 |
| user output |
|---|
| (empty) |
Test 14
Group: 4
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 1000000000 1000000000 100 2000... |
| correct output |
|---|
| 2003899199298 2016897879262 20... |
| user output |
|---|
| (empty) |
Test 15
Group: 4
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 1000000000 1000000000 100 2000... |
| correct output |
|---|
| 1267960483393 1326958437362 12... |
| user output |
|---|
| (empty) |
Test 16
Group: 4
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 1000000000 1000000000 10000 20... |
| correct output |
|---|
| 26998778013 13999380552 239989... |
| user output |
|---|
| (empty) |
Test 17
Group: 4
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 1000000000 1000000000 10000 20... |
| correct output |
|---|
| 7999699356 8999760379 12999665... |
| user output |
|---|
| (empty) |
