1525: 퍼즐

ewillwin·2023년 10월 23일
0

Problem Solving (BOJ)

목록 보기
223/230

문제 링크

1525: 퍼즐


구현 방식

  • bfs를 통한 완전탐색으로 풀어주었다
  • 주어진 시간 내에 완전탐색을 수행해주기 위해, board를 1차원 string으로 정의해 주었고, 중복 제거 및 이동 횟수 저장을 dictionary로 처리해주었다

코드

import sys
from collections import deque

dx = (0, 0, -1, 1)
dy = (-1, 1, 0, 0)

board = ""
for _ in range(3): tmp = sys.stdin.readline().strip(); tmp = tmp.replace(" ", ""); board += tmp

queue = deque([]); queue.append(board)
count = dict(); count[board] = 0

while queue:
    curr = queue.popleft()

    if curr == "123456780":
        print(count[curr])
        exit()
    
    idx = curr.index("0")
    x = idx // 3; y = idx % 3

    for i in range(4):
        nx, ny = x+dx[i], y+dy[i]
        if 0<=nx<3 and 0<=ny<3:
            nidx = nx*3 + ny
            next = list(curr)
            next[nidx], next[idx] = next[idx], next[nidx]
            next = "".join(next)

            if next not in count:
                queue.append(next)
                count[next] = count[curr] + 1
print(-1)
profile
💼 Software Engineer @ LG Electronics | 🎓 SungKyunKwan Univ. CSE

0개의 댓글