Submission details
Task:Monikulmio
Sender:Wiita
Submission time:2025-11-03 20:07:29 +0200
Language:Python3 (PyPy3)
Status:READY
Result:76
Feedback
groupverdictscore
#1ACCEPTED76
Test results
testverdicttimescore
#1ACCEPTED0.04 s7details
#2ACCEPTED0.07 s10details
#3ACCEPTED0.07 s7details
#4ACCEPTED0.07 s7details
#5ACCEPTED0.07 s7details
#6ACCEPTED0.06 s7details
#7ACCEPTED0.11 s7details
#8ACCEPTED0.12 s7details
#9ACCEPTED0.13 s10details
#10ACCEPTED0.37 s7details

Code

n, m, k = map(int, input().split())

ruudukko = {}
# Alusta ruudukko
for y in range(int(n)):
    for x in range(int(m)):
        ruudukko[f"{y},{x}"] = "#"

pisteet = []
for i in range(int(k)):
    y, x = input().split()
    pisteet.append([int(y) - 1,int(x) - 1])


# nuudeli koodi joka tekee janat
for piste in range(len(pisteet)):
    piste1 = pisteet[piste]
    piste2 = pisteet[(piste + 1) % k]

    y,x = piste1[0], piste1[1]
    while True:

        dy = (piste1[0] < piste2[0]) - (piste1[0] > piste2[0])
        dx = (piste1[1] < piste2[1]) - (piste1[1] > piste2[1])

        merkki = "."
        if y == piste2[0] and x == piste2[1] or y == piste1[0] and x == piste1[1]:
            merkki = "*"
        elif dy == 0:
            merkki = "="
        elif dx == 0:
            merkki = "|"
        elif dy == dx:
            merkki = "\\"
        else:
            merkki = "/"
            

        ruudukko[f"{y},{x}"] = merkki
        
        if y == piste2[0] and x == piste2[1]:
            break

        y += dy
        x += dx



def point_in_poly(px, py, verts):
    inside = False
    n = len(verts)
    for i in range(n):
        x1, y1 = verts[i]
        x2, y2 = verts[(i + 1) % n]
        if (y1 > py) != (y2 > py):
            x_intersect = x1 + (py - y1) * (x2 - x1) / (y2 - y1)
            if px < x_intersect:
                inside = not inside
    return inside

verts = [(p[1], p[0]) for p in pisteet]

for y in range(n):
    for x in range(m):
        key = f"{y},{x}"
        if ruudukko[key] in ("*", "=", "|", "/", "\\"):
            continue
        px = x + 0.5
        py = y + 0.5
        if point_in_poly(px, py, verts):
            ruudukko[key] = "#"
        else:
            ruudukko[key] = "."



# Tulosta ruudukko
for y in range(n):
    for x in range(m):
        print(ruudukko[f"{y},{x}"], end="")
    print("")

Test details

Test 1 (public)

Verdict: ACCEPTED

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

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

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

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

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
.................................

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

Test 4 (public)

Verdict: ACCEPTED

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

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

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

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

Test 5 (public)

Verdict: ACCEPTED

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

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

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

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

Test 6 (public)

Verdict: ACCEPTED

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

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

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

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

Test 7 (public)

Verdict: ACCEPTED

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

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

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

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

Test 8 (public)

Verdict: ACCEPTED

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

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

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

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

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
...*====*........................

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