Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- reinforcement learning
- 내용추가
- 알고리즘
- coding test
- 모두를 위한 딥러닝
- 백준
- computer vision
- object detection
- 논문
- 프로그래머스
- Python
Archives
- Today
- Total
NISSO
[백준 11729] 재귀함수로 하노이탑 이동하기 본문
나에게 혼란을 줬던 문제다.
직접 그려봐도 알 것 같은 느낌만 주고 전혀 모르겠던 문제.
재귀는 BFS/DFS로 가는 길에 얼른 풀어보고 끝내려고 했으나 난관이었다.
하지만 그만큼 중요하고 기본적인(?) 문제다.
코드를 보기 전에 문제 해결 방법을 먼저 이해하려고 본 유튜브 영상이다.
영어 영상들 사이에서 고마운 영상이었다. (문제 규칙을 이해했다면 3:37부터, 근데 앞부분 설명이 재밌음)
하지만 영상을 두 번 봐도 내 머리로는 정확히 이해가 안 돼서 바로 코드를 봤다.
def hanoi(n, start, end):
if n==1:
print(start, end)
return
hanoi(n-1, start, 6-start-end)
print(start, end)
hanoi(n-1, 6-start-end, end)
n = int(input())
print(2**n-1)
hanoi(n,1,3)
답은 이렇다.
사실 아직도 제대로 이해한 건 아니다.
다만 이동 횟수가 이렇게 간단할 줄이야. 그려보고서도 몰랐다.
이동 횟수는 2**n-1이고 이동경로는 함수 내 print()로 출력한다.
start : 이동할 원판이 있는 장대 (현재 장대)
end : 이동할 장대
그러니까 start 맨 위의 원판이 end로 이동되는 것이다.
여기서 제일 이해하기 힘들었던 6은 장대 번호를 다 더한 1+2+3이고, 6-start-end는 두 장대 외의 나머지 장대 번호를 표현한 것이다.
return은 꼭 필요하다. 없으면 에러 난다. (궁금해서 지워봄)
return 0을 하던, 100을 하던, 문자열을 쓰던 상관은 없지만 어쨌든 꼭 필요하다.
이 문제는 비슷하거나 같은 문제로 여러 번 복습해야겠다..
'Coding Test' 카테고리의 다른 글
[백준 15651] 백트래킹 (완전탐색) (0) | 2021.06.27 |
---|---|
[백준 2108] 시간초과와 런타임에러 (0) | 2021.06.27 |
[백준 10870] 피보나치 수 계산 - 재귀 / DP (0) | 2021.06.25 |
[백준 10872] 재귀함수로 팩토리얼 구현 (0) | 2021.06.25 |
[백준 4344] 평균은 넘겠지 (0) | 2021.06.25 |
Comments