-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy pathhouse_robber.rb
31 lines (27 loc) · 1.04 KB
/
house_robber.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# https://leetcode.com/problems/house-robber/
#
# You are a professional robber planning to rob houses along a street. Each
# house has a certain amount of money stashed, the only constraint stopping
# you from robbing each of them is that adjacent houses have security system
# connected and it will automatically contact the police if two adjacent
# houses were broken into on the same night.
#
# Given a list of non-negative integers representing the amount of money of
# each house, determine the maximum amount of money you can rob tonight
# without alerting the police.
#
# Credits:
#
# Special thanks to @ifanchu for adding this problem and creating all
# test cases. Also thanks to @ts for adding additional test cases.
# @param {Integer[]} nums
# @return {Integer}
def rob(nums)
rob_include_nth, rob_exclude_nth = 0, 0
nums.each do |num|
rob_include_nth, rob_exclude_nth =
rob_exclude_nth + num, [rob_exclude_nth, rob_include_nth].max
end
return rob_include_nth if rob_include_nth > rob_exclude_nth
return rob_exclude_nth
end