PS/백준

골드5 뱀과 사다리 게임(16928)

2023. 12. 28. 18:39
 

16928번: 뱀과 사다리 게임

첫째 줄에 게임판에 있는 사다리의 수 N(1 ≤ N ≤ 15)과 뱀의 수 M(1 ≤ M ≤ 15)이 주어진다. 둘째 줄부터 N개의 줄에는 사다리의 정보를 의미하는 x, y (x < y)가 주어진다. x번 칸에 도착하면, y번 칸으

www.acmicpc.net

이 문제를 풀면서 어떻게 BFS를 통해서 최소 탐색을 할 지 고민을 했습니다. 그래서 1~6을 추가해가면서 100이 되는 것을 확인해야한다고 생각했는데, 어떻게 풀어 나갈지가 가장 문제였다. 기존과 비슷하게 BFS를 진행하고, 각 경우의 수를 나누어 풀어나갔다.

import sys
from collections import deque
input = sys.stdin.readline

def bfs(start):
  q = deque([start])
  visited[start] = 0
  while q:
    v = q.popleft()
    if v == 100: break
    for d in (1,2,3,4,5,6):
      nextD = v + d
      if (0 <= nextD <= 100) and (not visited[nextD]):
        if nextD in ladder.keys():
          nextD = ladder[nextD]
        elif nextD in snake.keys():
          nextD = snake[nextD]
        if not visited[nextD]:
          q.append(nextD)
          visited[nextD] = visited[v] + 1

n, m = map(int, input().split())
visited = [0] * 101 # 이전 단계에 대한 횟수를 저장해놓을 것 + 0이 아니면 방문한걸로 판단
ladder = {int(x[0]): int(x[1]) for x in [input().split() for _ in range(n)]}
snake = {int(x[0]): int(x[1]) for x in [input().split() for _ in range(m)]}
bfs(1)
print(visited[-1])

사다리와 뱀은 딕셔너리를 활용해서 구현을 했습니다. 리스트로 풀면 n시간이지만 딕셔너리는 탐색시간이 줄어들어서 조금의 시간을 줄일 수 있다고 생각했습니다. 그리고 visited리스트를 TF로 넣은게 아니라 횟수로 구현했다. 그렇게 구현하면 0보다 크면 방문했다는 것으로 했습니다. 그 다음에 BFS를 구현했는데 대부분의 BFS와 같이 구현이 되고, 조건문에서 차례로 검사한다.  visited[nextD]를 마지막 if문에서 검사하는 이유는 nextD가 변경되어서 그것 마저 검사해서 큐에 넣어야하기 때문입니다. 이렇게 구현해서 성공했다.

'PS > 백준' 카테고리의 다른 글

실버3 구간 합 구하기 4(11659)  (0) 2023.12.30
실버3 1로 만들기(1463)  (0) 2023.12.30
골드5 토마토(7569)  (0) 2023.12.27
골드5 토마토(7576)  (1) 2023.12.26
실버1 나이트의 이동(7562)  (1) 2023.12.22
'PS/백준' 카테고리의 다른 글
  • 실버3 구간 합 구하기 4(11659)
  • 실버3 1로 만들기(1463)
  • 골드5 토마토(7569)
  • 골드5 토마토(7576)
jjw000628
jjw000628
jjw000628
wldnd2
jjw000628
전체
오늘
어제
  • 분류 전체보기 (27)
    • Skill Up (1)
      • Algorithm Theory (1)
      • Java (0)
      • JS (0)
      • 프로젝트 및 회고 (0)
    • PS (23)
      • 백준 (15)
      • 프로그래머스 (8)
    • Lab (3)
      • Basic Concept (0)
      • 무선 이동 통신 (3)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 파이썬
  • 프로그래머스
  • 분할정복
  • 브루트포스
  • C++
  • Cpp
  • 알고리즘
  • BFS
  • 백준
  • 파싱
  • 그래프
  • 문자열
  • 재귀
  • 누적합
  • 너비우선탐색
  • JS
  • 깊이우선탐색
  • 네트워크
  • 그래프탐색
  • 정규식
  • dfs
  • 무선
  • DP

최근 댓글

최근 글

hELLO · Designed By 정상우.
jjw000628
골드5 뱀과 사다리 게임(16928)
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.