코딩테스트/알고리즘

99클럽 코테 스터디 7일차 TIL + 하노이의 탑

Porits789 2024. 7. 29. 10:07

오늘의 학습 키워드: 재귀

문제: 하노이의 탑

https://school.programmers.co.kr/learn/courses/30/lessons/12946

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

풀이

이번 풀이는 재귀를 이용해 진행했습니다.

 

아이디어는 이렇습니다.

  • 2번(중간지점)을 목표로 n-1개의 층을 이동시킵니다.
  • 최하단의 층만 남는 경우에 이를 3번(목표지점)으로 이동시킵니다.
  • 이후 중간지점과 시작지점을 서로 바꾸어 위의 과정을 진행합니다.
def solution(n):
    answer = []
    def f(n,src,aux,tar): # n, source, aux, target
        if n == 1:
            answer.append([src,tar])
        else:
            f(n-1,src,tar,aux)
            f(1,src,aux,tar)
            f(n-1,aux,src,tar)
    f(n,1,2,3)
    return answer

회고

밀리는 감이 없지 않은데 빠르게 포스팅하려 합니다.

 

내일 학습할 것.

SQL, Python, 독서