| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | ||||||
| 2 | 3 | 4 | 5 | 6 | 7 | 8 |
| 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 | 20 | 21 | 22 |
| 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 30 |
Tags
- BFS
- java #자바 #생활코딩
- PYTHON
- 농구
- 재귀
- 백트랙킹
- 코딩테스트
- dp
- 백준 #파이썬 #알고리즘 #코딩테스트
- 프로그래머스 #파이썬 #알고리즘 #코딩테스트
- java #자바 #동빈나
- 파이썬 #백준 #알고리즘 #코딩테스트
- 다이나믹프로그래밍
- css #생활코딩 #웹
- java #자바
- 알고리즘
- 자바 #java
- react #리액트 #동빈나 #나동빈 #유튜브강의
- 파이썬
- DFS
- 프로그래머스 #파이썬 #코딩테스트 #알고리즘
- 백준 #알고리즘 #파이썬 #코딩테스트
- 투포인터
- 다익스트라
- css #웹 #생활코딩
- java #자바 #나동빈
- Dijkstra
- 프로그래머스
- 파이썬 #알고리즘 #코딩테스트 #프로그래머스
- 백준
Archives
- Today
- Total
커리까지
[백준] 7562번 나이트의 이동 파이썬 본문
728x90
SMALL
문제
체스판 위에 한 나이트가 놓여져 있다. 나이트가 한 번에 이동할 수 있는 칸은 아래 그림에 나와있다. 나이트가 이동하려고 하는 칸이 주어진다. 나이트는 몇 번 움직이면 이 칸으로 이동할 수 있을까?

입력
입력의 첫째 줄에는 테스트 케이스의 개수가 주어진다.
각 테스트 케이스는 세 줄로 이루어져 있다. 첫째 줄에는 체스판의 한 변의 길이 l(4 ≤ l ≤ 300)이 주어진다. 체스판의 크기는 l × l이다. 체스판의 각 칸은 두 수의 쌍 {0, ..., l-1} × {0, ..., l-1}로 나타낼 수 있다. 둘째 줄과 셋째 줄에는 나이트가 현재 있는 칸, 나이트가 이동하려고 하는 칸이 주어진다.
출력
각 테스트 케이스마다 나이트가 최소 몇 번만에 이동할 수 있는지 출력한다.
예제 입력 1
3
8
0 0
7 0
100
0 0
30 50
10
1 1
1 1예제 출력 1
5
28
0
제출 답안
from collections import deque
import sys
input = sys.stdin.readline
dy = [1,2,2,1,-1,-2,-2,-1]
dx = [2,1,-1,-2,-2,-1,1,2]
t = int(input())
answer = []
def bfs(graph,a, b, j, i):
n = len(graph)
q = deque([(a, b)])
while q:
y, x = q.popleft()
if y == j and x == i:
return graph[j][i]
for k in range(8):
ny = y + dy[k]
nx = x + dx[k]
if 0 <= ny < n and 0 <= nx < n:
if graph[ny][nx] == 0:
graph[ny][nx] = graph[y][x] + 1
q.append((ny, nx))
return graph[j][i]
for _ in range(t):
n = int(input())
graph = [[0] * n for _ in range(n)]
a, b = map(int, input().split())
graph[a][b] = 1
y, x = map(int, input().split())
cnt = bfs(graph, a, b, y ,x)
answer.append(cnt-1)
print(*answer, sep='\n')728x90
LIST
'알고리즘 > 풀이' 카테고리의 다른 글
| [백준] 스타트 링크 파이썬 (0) | 2023.07.24 |
|---|---|
| [백준] 1926번 그림 파이썬 (0) | 2023.07.22 |
| [백준] 2583 영역 구하기 파이썬 (0) | 2023.07.20 |
| [백준] 4963번 섬의 개수 파이썬 (0) | 2023.07.19 |
| [프로그래머스] 택배 배달과 수거하기 파이썬 (0) | 2023.07.11 |
Comments