Skip to content

Commit 30322dc

Browse files
committed
add solution: house robber ii
1 parent 517b59d commit 30322dc

File tree

1 file changed

+51
-0
lines changed

1 file changed

+51
-0
lines changed

house-robber-ii/flynn.go

Lines changed: 51 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,51 @@
1+
/*
2+
풀이
3+
- house robber 문제와 비슷합니다
4+
이전 풀이 링크: https://github.com/DaleStudy/leetcode-study/pull/576/files#diff-a98dce0d933d299b3b8e2cc345b95a398c894391b7b86b4b85e3c0aea9d0757f
5+
- 첫번째 집을 터는 경우와 안 터는 경우를 나누어 계산합니다
6+
Big O
7+
- N: 주어진 배열 nums의 길이
8+
- Time complexity: O(N)
9+
- Space complexity: O(1)
10+
*/
11+
12+
import "slices"
13+
14+
func rob(nums []int) int {
15+
n := len(nums)
16+
17+
if n < 4 {
18+
return slices.Max(nums)
19+
} else if n == 4 {
20+
return max(nums[0]+nums[2], nums[1]+nums[3])
21+
}
22+
23+
// rob nums[0] (can't rob nums[1] and nums[n-1])
24+
robFirst := nums[0]
25+
ppRobbed := nums[2] // initial value = nums[2] because we can't rob nums[1]
26+
pRobbed := nums[3]
27+
pUnrobbed := nums[2]
28+
for i := 4; i < n-1; i++ { // i < n-1 because we can't rob nums[n-1]
29+
ppRobbed, pRobbed, pUnrobbed = pRobbed, nums[i]+max(ppRobbed, pUnrobbed), max(pRobbed, pUnrobbed)
30+
}
31+
robFirst += max(pRobbed, pUnrobbed)
32+
33+
// skip nums[0]
34+
ppRobbed = nums[1]
35+
pRobbed = nums[2]
36+
pUnrobbed = nums[1]
37+
for i := 3; i < n; i++ {
38+
ppRobbed, pRobbed, pUnrobbed = pRobbed, nums[i]+max(ppRobbed, pUnrobbed), max(pRobbed, pUnrobbed)
39+
}
40+
skipFirst := max(pRobbed, pUnrobbed)
41+
42+
return max(robFirst, skipFirst)
43+
}
44+
45+
func max(a, b int) int {
46+
if a > b {
47+
return a
48+
} else {
49+
return b
50+
}
51+
}

0 commit comments

Comments
 (0)