Submission details
Task:Monikulmio
Sender:Sode
Submission time:2025-11-02 13:33:02 +0200
Language:Python3 (PyPy3)
Status:READY
Result:100
Feedback
groupverdictscore
#1ACCEPTED100
Test results
testverdicttimescore
#1ACCEPTED0.04 s10details
#2ACCEPTED0.06 s10details
#3ACCEPTED0.07 s10details
#4ACCEPTED0.07 s10details
#5ACCEPTED0.06 s10details
#6ACCEPTED0.06 s10details
#7ACCEPTED0.10 s10details
#8ACCEPTED0.10 s10details
#9ACCEPTED0.10 s10details
#10ACCEPTED0.34 s10details

Code

def c(polygon, point):
    x, y = point
    n = len(polygon)
    inside = False
    for i in range(n):
        x1, y1 = polygon[i]
        x2, y2 = polygon[(i + 1) % n]
        if y > min(y1, y2):
            if y <= max(y1, y2):
                if x <= max(x1, x2):
                    if y1 != y2:
                        x_intersect = (y - y1) * (x2 - x1) / (y2 - y1) + x1
                    if x1 == x2 or x <= x_intersect:
                        inside = not inside
    return inside

n, m, k = map(int, input().split())
a = []
for _ in range(k):
    y, x = map(int, input().split())
    a.append((x - 1, y - 1)) 

b = [['.' for _ in range(m)] for _ in range(n)]

for x, y in a:
    b[y][x] = '*'

for i in range(k):
    x1, y1 = a[i]
    x2, y2 = a[(i + 1) % k] 

    dy = y2 - y1
    dx = x2 - x1

    if dx == 0: 
        step = 1 if dy > 0 else -1
        for y in range(y1, y2 + step, step):
            if b[y][x1] == '.':
                b[y][x1] = '|'
    elif dy == 0:
        step = 1 if dx > 0 else -1
        for x in range(x1, x2 + step, step):
            if b[y1][x] == '.':
                b[y1][x] = '='
    elif abs(dx) == abs(dy):
        step_y = 1 if dy > 0 else -1
        step_x = 1 if dx > 0 else -1
        y, x = y1, x1
        while y != y2 or x != x2:
            y += step_y
            x += step_x
            if b[y][x] == '.':
                if dx > 0 and dy > 0:
                    b[y][x] = '\\'
                elif dx > 0 and dy < 0:
                    b[y][x] = '/'
                elif dx < 0 and dy > 0:
                    b[y][x] = '/'
                elif dx < 0 and dy < 0:
                    b[y][x] = '\\'

for y in range(n):
    for x in range(m):
        if b[y][x] == '.':
            if c(a, (x, y)):
                b[y][x] = '#'

for row in b:
    print(''.join(row))

Test details

Test 1 (public)

Verdict: ACCEPTED

input
8 9 5
5 2
2 5
5 8
7 8
...

correct output
.........
....*....
.../#\...
../###\..
.*#####*.
...

user output
.........
....*....
.../#\...
../###\..
.*#####*.
...

Test 2 (public)

Verdict: ACCEPTED

input
20 40 4
5 10
5 30
15 30
15 10

correct output
.................................

user output
.................................

Test 3 (public)

Verdict: ACCEPTED

input
20 40 29
8 7
13 2
14 2
9 7
...

correct output
.................................

user output
.................................

Test 4 (public)

Verdict: ACCEPTED

input
20 40 14
5 12
5 25
8 28
13 28
...

correct output
.................................

user output
.................................

Test 5 (public)

Verdict: ACCEPTED

input
20 40 12
3 20
7 16
7 9
11 13
...

correct output
.................................

user output
.................................

Test 6 (public)

Verdict: ACCEPTED

input
9 35 33
2 3
2 8
4 8
4 5
...

correct output
.................................

user output
.................................

Test 7 (public)

Verdict: ACCEPTED

input
30 100 69
6 10
6 14
7 14
7 18
...

correct output
.................................

user output
.................................

Test 8 (public)

Verdict: ACCEPTED

input
40 60 192
11 3
11 5
10 6
11 7
...

correct output
.................................

user output
.................................

Test 9 (public)

Verdict: ACCEPTED

input
50 100 142
1 1
1 7
1 11
1 14
...

correct output
*=====*===*==*...................

user output
*=====*===*==*...................

Test 10 (public)

Verdict: ACCEPTED

input
100 100 1000
10 1
4 7
1 4
1 9
...

correct output
...*====*........................

user output
...*====*........................