문제
https://leetcode.com/problems/house-robber/description/
도둑이 집을 털려고 한다. 인접해 있는 연속된 집을 털면 경찰에 발각된다. 각 집에 있는 돈이 담긴 배열인 nums
가 주어졌을 때 도둑이 경찰에게 걸리지 않고 오늘 밤에 털 수 있는 최대 금액을 구하는 문제
풀이
아이디어
어떤 집을 턴다고 했을 때 최대 금액을 구하는 식은 아래와 같이 세울 수 있다.: Math.max(전 집을 털었을 때의 최대 금액, 전전 집을 털었을 때의 최대 금액 + 지금 집을 털었을 때 얻는 금액) 점화식을 세웠으니… Dynamic Programming으로 푼다. 연산 횟수를 줄여주기 위해서 메모 배열을 이용했다.
코드
function rob(nums: number[]): number {
const n = nums.length;
if (n === 1) {
return nums[0];
}
// idx 집을 터는 경우 vs 안 터는 경우를 비교해서 큰 값을 저장하는 dp 배열
const memo = new Array(n).fill(0);
memo[0] = nums[0];
memo[1] = Math.max(memo[0], nums[1]);
for (let idx = 2; idx < n; idx++) {
// idx번째 집에서의 최대 금액 = idx번째 집을 터는 경우 vs 안 터는 경우 중 최댓값
memo[idx] = Math.max(memo[idx - 2] + nums[idx], memo[idx - 1]);
}
return memo[n - 1];
}
시간 / 공간 복잡도
for loop 에서 nums 배열의 각 원소에 한번씩만 접근하므로 시간 복잡도는 **O(n)**이 된다.
n만큼의 배열을 만들기 때문에 공간 복잡도 역시 **O(n)**이 된다.