| Task: | Monikulmio |
| Sender: | Wiita |
| Submission time: | 2025-11-03 20:09:45 +0200 |
| Language: | Python3 (PyPy3) |
| Status: | READY |
| Result: | 100 |
| group | verdict | score |
|---|---|---|
| #1 | ACCEPTED | 100 |
| test | verdict | time | score | |
|---|---|---|---|---|
| #1 | ACCEPTED | 0.04 s | 10 | details |
| #2 | ACCEPTED | 0.07 s | 10 | details |
| #3 | ACCEPTED | 0.07 s | 10 | details |
| #4 | ACCEPTED | 0.07 s | 10 | details |
| #5 | ACCEPTED | 0.07 s | 10 | details |
| #6 | ACCEPTED | 0.06 s | 10 | details |
| #7 | ACCEPTED | 0.11 s | 10 | details |
| #8 | ACCEPTED | 0.12 s | 10 | details |
| #9 | ACCEPTED | 0.12 s | 10 | details |
| #10 | ACCEPTED | 0.35 s | 10 | details |
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] + 0.5, p[0] + 0.5) 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 |
|---|
| ......... ....*.... .../#\... ../###\.. .*#####*. ... |
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 |
|---|
| ...*====*........................ |
