Submission details
Task:Monikulmio
Sender:Username*
Submission time:2025-10-31 20:25:48 +0200
Language:Python3 (CPython3)
Status:READY
Result:94
Feedback
groupverdictscore
#1ACCEPTED94
Test results
testverdicttimescore
#1ACCEPTED0.02 s10details
#2ACCEPTED0.03 s10details
#3ACCEPTED0.03 s10details
#4ACCEPTED0.03 s10details
#5ACCEPTED0.03 s10details
#6ACCEPTED0.02 s10details
#7ACCEPTED0.03 s10details
#8ACCEPTED0.03 s10details
#9ACCEPTED0.04 s7details
#10ACCEPTED0.04 s7details

Code

import collections

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

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

for i in range(k):
    y1, x1 = p[i]
    y2, x2 = p[(i + 1) % k]
    
    g[y1][x1] = '*'
    
    dy = y2 - y1
    dx = x2 - x1
    l = max(abs(dy), abs(dx))
    
    sy = 0 if dy == 0 else dy // abs(dy)
    sx = 0 if dx == 0 else dx // abs(dx)
    
    ch = ''
    if sy == 0: ch = '='
    elif sx == 0: ch = '|'
    elif sy * sx > 0: ch = '\\'
    else: ch = '/'
    
    for j in range(1, l):
        cy = y1 + j * sy
        cx = x1 + j * sx
        g[cy][cx] = ch

q = collections.deque()
v = set()

def aq(r, c):
    if 0 <= r < n and 0 <= c < m and (r, c) not in v and g[r][c] == '.':
        q.append((r, c))
        v.add((r, c))

for r in range(n):
    aq(r, 0)
    aq(r, m - 1)

for c in range(m):
    aq(0, c)
    aq(n - 1, c)

while q:
    r, c = q.popleft()
    aq(r + 1, c)
    aq(r - 1, c)
    aq(r, c + 1)
    aq(r, c - 1)
    
    if r + 1 < n and c + 1 < m and g[r+1][c] == '.' and g[r][c+1] == '.':
        aq(r + 1, c + 1)
    if r + 1 < n and c - 1 >= 0 and g[r+1][c] == '.' and g[r][c-1] == '.':
        aq(r + 1, c - 1)
    if r - 1 >= 0 and c + 1 < m and g[r-1][c] == '.' and g[r][c+1] == '.':
        aq(r - 1, c + 1)
    if r - 1 >= 0 and c - 1 >= 0 and g[r-1][c] == '.' and g[r][c-1] == '.':
        aq(r - 1, c - 1)

for r in range(n):
    for c in range(m):
        if g[r][c] == '.' and (r, c) not in v:
            g[r][c] = '#'

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

Feedback: Lines are drawn correctly. Incorrect fill character on row 3, col 9: expected '.', got '#'

Test 10 (public)

Verdict: ACCEPTED

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

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

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

Feedback: Lines are drawn correctly. Incorrect fill character on row 4, col 29: expected '.', got '#'