피보나치수열(3)
-
Python 84 - 다이나믹 프로그래밍 실전문제2 ("개미 전사")
난이도 ●●○ l 풀이 시간 30분 l 시간 제한 1초 l 메모리 제한 128MB l 문제 개미 전사는 부족한 식량을 충당하고자 메뚜기 마을의 식량창고를 몰래 공격하려고 한다. 메뚜기 마을에는 여러 개의 식량 창고가 있는데 식량창고는 일직선으로 이어져 있다. 각 식량창고에는 정해진 수의 식량을 저장하고 있으며 개미 전사는 식량창고를 선택적으로 약탈하여 식량을 빼앗을 예정이다. 이때 메뚜기 정찰병들은 일직선상에 존재하는 식량창고 중에서 서로 인접한 식량창고가 공격받으면 바로 알아챌 수 있다. 따라서 개미 전사가 정찰병에게 들키지 않고 식량창고를 약탈하기 위해서는 최소한 한 칸 이상 떨어진 식량창고를 약탈해야 한다. 예를 들어 식량창고 4개가 다음과 같이 존재한다고 가정하자. {1, 3, 1, 5} 1 3 ..
2021.07.19 -
Python 83 - 다이나믹 프로그래밍 실전문제1 ("1로 만들기")
난이도 ●◐○ l 풀이 시간 20분 l 시간 제한 1초 l 메모리 제한 128MB l 문제 정수 X가 주어질 때 정수 X에 사용할 수 있는 연산은 다음과 같이 4가지이다. ⓐ X가 5로 나우어떨어지면 5로 나눈다. ⓑ X가 3으로 나누어떨어지면 3으로 나눈다. ⓒ X가 2로 나누어떨어지면 2로 나눈다. ⓓ X에서 1을 뺸다. 정수 X가 주어졌을 때, 연산 4개를 적절히 사용해서 1을 만들려고 한다. 연산을 사용하는 횟수의 최솟값을 출력하시오. 예를 들어 정수가 26이면 다음과 같이 계산해서 3번의 연산이 최솟값이다. 26 - 1 = 25 (ⓓ) 25 / 5 = 5 (ⓐ) 5 / 5 = 1 (ⓐ) 입력조건 첫째 줄에 정수가 X가 주어진다. ( 1
2021.07.18 -
Python 82 - 다이나믹 프로그래밍
중복되는 연산을 줄이자 현실 세계에는 다양한 문제가 있다. 그런데 이중에서 컴퓨터를 활용해도 해결하기 어려운 문제는 무엇일까? 최적의 해를 구하기에 시간이 매우 많이 필요하거나 메모리 공간이 매우 많이 필요한 문제 등이 컴퓨터로도 해결하기 어려운 문제이다. 컴퓨터는 연산 속도에 한계가 있고, 메모리 공간을 사용할 수 있는 데이터의 개수도 한정적이라는 점이 많은 제약을 발생시킨다. 그래서 우리는 연산 속도와 메모리 공간을 최대한으로 활용할 수 있는 효율적인 알고리즘을 작성해야 한다. 다만, 어떤 문제는 메모리 공간을 약간 더 사용하면 연산 속도를 비약적으로 증가시킬 수 있는 방법이 있다. 대표적인 방법이 바로 이번 장에서 다루는 다이나믹 프로그래밍(Dynamic Programming) 기법으로 동적 계획법..
2021.07.17