TIL #9 : 동적 계획법 & 분할 정복

tobi·2021년 8월 10일
0

알고리즘

목록 보기
1/8

📝 동적 계획법 (Dynamic Programming)

상향식 접근법으로, 가장 최하위 해답을 구한 후, 이를 저장하고 해당 결과값을 이용해서 상위 문제를 풀어가는 방식
ex) 피보나치 수열

  • 부분 문제는 중복되어, 상위 문제 해결 시 재활용 됨
  • Memoization 기법 사용
    : 프로그램 실행 시, 이전에 계산한 값을 저장하여 다시 계산하지 않도록 하여 전체 실행 속도를 빠르게 하는 기술

📝 분할 정복 (Divide and Conquer)

하향식 접근법으로, 상위의 해답을 구하기 위해 아래로 내려가면서 하위의 해답을 구하는 방식
ex) 이진 탐색, 병합 정렬, 퀵 정렬 등

  • 부분 문제는 서로 중복되지 않음
  • 재귀 함수 사용
profile
🌱 개발자

0개의 댓글