yooniiverse
개발 블로그
yooniiverse
전체 방문자
오늘
어제
  • 분류 전체보기
    • 운영체제
    • 네트워크
    • ~2023.02
      • 외부교육
      • 대외활동
      • 스터디
      • 동아리
      • TIL
      • IT지식
      • 기타
      • 트러블 슈팅
      • 프로그래밍
      • Python
      • Java
      • JS
      • DB(SQL)
      • JSP
      • Spring
      • 기술면접
      • 자바
      • 코딩테스트
      • 자료구조
      • 알고리즘
      • 백준 문제풀이
      • 인공지능
      • 머신러닝
      • 프로젝트
      • 안드로이드 앱개발
      • 웹개발
      • 웹 서비스
      • 웹퍼블리싱
      • Node.js 백엔드 개발
      • CS
      • 1일 1CS지식
      • 운영체제
      • 네트워크
      • 데이터베이스
      • 정보처리기사
      • 도서 리뷰
      • 개발 관련 도서
      • 기타 도서

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
yooniiverse

개발 블로그

~2023.02/알고리즘

동적 계획법과 분할 정복

2022. 2. 23. 20:45

동적계획법


  • 입력 크기가 작은 부분 문제들을 해결한 후, 해당 부분 문제의 해를 활용해서, 보다 큰 크기의 부분 문제를 해결, 최종적으로 전체 문제를 해결하는 알고리즘
  • 상향식 접근법으로, 가장 최하위 해답을 구한 후, 이를 저장하고, 해당 결과값을 이용해서 상위 문제를 풀어가는 방식
  • 메모이제이션 기법 사용
  • 메모이제이션 이란 -> 프로그램 실행 시 이전에 계산한 값을 저장하여, 다시 계산하지 않도록 하여 전체 실행 속도를 빠르게 하는 기술
  • 문제를 잘게 쪼갤 때, 부분 문제는 중복되어, 재활용 됨 (예) 피보나치 수열)

 

분할 정복


  • 문제를 나눌 수 없을 때까지 나누어서 각각을 풀면서 다시 병합하여 문제의 답을 얻는 알고리즘
  • 하향식 접근법으로, 상위의 해답을 구하기 위해, 아래로 내려가면서 하위의 해답을 구하는 방식 => 일반적으로 재귀함수로 구현
  • 문제를 잘게 쪼갤 때, 부분 문제는 서로 중복되지 않음 (예) 병합 정렬, 퀵 정렬 등)

 

공통점과 차이점


[공통점]

  • 문제를 잘게 쪼개서, 가장 작은 단위로 분할

[차이점]

  • 동적 계획법
    • 부분 문제는 중복되어, 상위 문제 해결 시 재활용됨
    • 메모이제이션 기법 사용
  • 분할 정복
    • 부분 문제는 서로 중복되지 않음
    • 메모이제이션 기법 사용x

 

recursive call 활용


def fibo(num):
    if num <= 1:
        return num
    return fibo(num - 1) + fibo(num - 2)
print(fibo(10))

 

동적 계획법 활용


def fibo(num):
    cache = [0 for index in range(num + 1)]  # 파이썬 comprehension
    cache[0] = 0
    cache[1] = 1
    
    for index in range(2, num + 1):
        cache[index] = cache[index - 1] + cache[index - 2]
    return cache[num]

https://www.fun-coding.org/PL&OOP5-2.html

 

파이썬 특수 문법(데코레이터, 이터레이터등): 파이썬 Comprehension - 잔재미코딩

초간단 연습1 1. List comprehension을 사용해서 1~100까지의 숫자 출력하기 2. List comprehension을 사용해서 1~100까지의 숫자 중 3으로 나누어 떨어지는 수만 출력하기 3. List comprehension을 사용해서 1~100까지

www.fun-coding.org

https://pythontutor.com/visualize.html#mode=display

 

Python Tutor - Visualize Python, Java, JavaScript, C, C++, Ruby code execution

Write code in Python 3.6 Java 8 JavaScript ES6 C (gcc 9.3, C17 + GNU extensions) C++ (g++ 9.3, C++20 + GNU extensions) ------ [unsupported] Python 2.7 [unsupported] C (gcc 4.8, C11) [unsupported] C++ (g++ 4.8, C++11) [unsupported] TypeScript 1.4 [unsupport

pythontutor.com

 

분할 정복 활용


  • 별도 챕터에서 다루는 병합 정렬과 퀵 정렬을 통해 이해

 

실전코딩테스트-동적계획법


[풀이 전략]

  • 점화식을 찾아보자
    • 점화식이란, 이웃하는 두 개의 항 사이에 성립하는 관계를 나타낸 관계식을 의미함
    • 예) dp[n + 3] = dp[n + 1] + dp[n + 2]

[백준 11726번]

https://www.acmicpc.net/problem/11726

 

11726번: 2×n 타일링

2×n 크기의 직사각형을 1×2, 2×1 타일로 채우는 방법의 수를 구하는 프로그램을 작성하시오. 아래 그림은 2×5 크기의 직사각형을 채운 한 가지 방법의 예이다.

www.acmicpc.net

"""
패턴
1. 빈 리스트 만들기(입력값에 따른)
2. 초기값을 설정
3. 점화식 기반으로 계산값 적용하기
4. 특정 입력값에 따른 계산값을 리스트에서 추출하기
"""
# 1
dp = [0] * 1001

#2
dp[1] = 1
dp[2] = 2

#3
for index in range(3, 1001):
    dp[index] = dp[index - 1] + dp[index - 2]

#4
print(dp[9])

[백준 9461번]

https://www.acmicpc.net/problem/9461

 

9461번: 파도반 수열

오른쪽 그림과 같이 삼각형이 나선 모양으로 놓여져 있다. 첫 삼각형은 정삼각형으로 변의 길이는 1이다. 그 다음에는 다음과 같은 과정으로 정삼각형을 계속 추가한다. 나선에서 가장 긴 변의

www.acmicpc.net

dp = [0] * 101
dp[1], dp[2], dp[3] = 1, 1, 1
for i in range(1, 98):
    dp[i + 3] = dp[i] + dp[i + 1]

t = int(input())
for i in range(t):
    n = int(input())
    print(dp[n])

[백준 1904번]

https://www.acmicpc.net/problem/1904

 

1904번: 01타일

지원이에게 2진 수열을 가르쳐 주기 위해, 지원이 아버지는 그에게 타일들을 선물해주셨다. 그리고 이 각각의 타일들은 0 또는 1이 쓰여 있는 낱장의 타일들이다. 어느 날 짓궂은 동주가 지원이

www.acmicpc.net

n = int(input())

def fibo(n):
    cache = [0 for i in range(n + 1)]
    cache[1] = 1
    cache[2] = 2

    for i in range(3, n + 1):
        cache[i] = (cache[i - 2] + cache[i - 1]) % 15746
    return cache[n]
print(fibo(n))

'~2023.02 > 알고리즘' 카테고리의 다른 글

[탐색 알고리즘 #3] 코딩 테스트 연습문제 풀이  (0) 2022.02.25
[탐색 알고리즘 #2] 순차 탐색(Sequential Search)  (0) 2022.02.25
[탐색 알고리즘 #1] 이진 탐색(Binary Search)  (0) 2022.02.25
탐욕 알고리즘(그리디)  (0) 2022.02.23
그래프 기본 탐색 알고리즘_너비 우선 탐색(BFS)  (0) 2022.01.15
    '~2023.02/알고리즘' 카테고리의 다른 글
    • [탐색 알고리즘 #2] 순차 탐색(Sequential Search)
    • [탐색 알고리즘 #1] 이진 탐색(Binary Search)
    • 탐욕 알고리즘(그리디)
    • 그래프 기본 탐색 알고리즘_너비 우선 탐색(BFS)
    yooniiverse
    yooniiverse

    티스토리툴바