BOJ 18404 - 현명한 나이트 (Python)

조민수·2024년 4월 8일
0

BOJ

목록 보기
40/64
post-thumbnail

S1, BFS


풀이

  • 시간초과를 고려해야 했던 문제
from sys import stdin
from collections import deque

n, m = map(int, stdin.readline().split())
graph = [[0] * n for _ in range(n)]
x, y = map(int, stdin.readline().split())
x -= 1
y -= 1

endPoint = []
for i in range(m):
    a, b = map(int, stdin.readline().split())
    a -= 1
    b -= 1
    endPoint.append([a, b])

res = []

def bfs(sx, sy):
    q = deque()
    q.append([sx, sy])
    visited[sx][sy] = 1

    dx,dy = [-1,-2,-2,-1,1,2,2,1], [-2,-1,1,2,-2,-1,1,2]

    while q:
        x, y = q.popleft()

        for i in range(8):
            nx, ny = x + dx[i], y + dy[i]
            if 0<=nx<n and 0<=ny<n and not visited[nx][ny]:
                q.append([nx,ny])
                visited[nx][ny] = visited[x][y] + 1


visited = [[0] * n for _ in range(n)]
bfs(x, y)

for x, y in endPoint:
    res.append(visited[x][y] - 1)

print(*res)
profile
사람을 좋아하는 Front-End 개발자

0개의 댓글