Submission details
Task:Monikulmio
Sender:Nyno
Submission time:2025-11-09 21:30:14 +0200
Language:Python3 (PyPy3)
Status:READY
Result:100
Feedback
groupverdictscore
#1ACCEPTED100
Test results
testverdicttimescore
#1ACCEPTED0.04 s10details
#2ACCEPTED0.06 s10details
#3ACCEPTED0.08 s10details
#4ACCEPTED0.07 s10details
#5ACCEPTED0.07 s10details
#6ACCEPTED0.06 s10details
#7ACCEPTED0.10 s10details
#8ACCEPTED0.11 s10details
#9ACCEPTED0.12 s10details
#10ACCEPTED0.56 s10details

Code

n, m, k = map(int, input().split())
points = [tuple(map(int, input().split())) for _ in range(k)]
grid = [[' ' for _ in range(m)] for _ in range(n)]


for i in range(k):
    y1, x1 = points[i]
    y2, x2 = points[(i + 1) % k]
    dy = (y2 > y1) - (y2 < y1)
    dx = (x2 > x1) - (x2 < x1)
    y, x = y1, x1
    while True:
        if (y, x) in points:
            grid[y-1][x-1] = '*'
        else:
            if dy == 0:
                grid[y-1][x-1] = '='
            elif dx == 0:
                grid[y-1][x-1] = '|'
            elif dy == dx:
                grid[y-1][x-1] = '\\'
            else:
                grid[y-1][x-1] = '/'
        if (y, x) == (y2, x2):
            break
        y += dy
        x += dx


def point_in_poly(x, y, poly):
    cnt = 0
    n = len(poly)
    for i in range(n):
        x1, y1 = poly[i][1]-1, poly[i][0]-1
        x2, y2 = poly[(i+1)%n][1]-1, poly[(i+1)%n][0]-1
        if y1 == y2:  
            continue
        if y < min(y1, y2) or y >= max(y1, y2):
            continue
        interx = x1 + (y - y1) * (x2 - x1) / (y2 - y1)
        if interx > x:
            cnt += 1
    return cnt % 2 == 1


for i in range(n):
    for j in range(m):
        if grid[i][j] == ' ':
            if point_in_poly(j, i, points):
                grid[i][j] = '#'
            else:
                grid[i][j] = '.'


for row in grid:
    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
...*====*........................