-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy path0198-house-robber.rs
33 lines (26 loc) · 1.13 KB
/
0198-house-robber.rs
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
32
33
/*
Problem: LeetCode 198 - House Robber
Key Idea:
The key idea is to use dynamic programming to find the maximum amount of money that can be robbed without alerting the police.
Approach:
1. Initialize two variables, `prev` and `curr`, to represent the maximum amount of money that can be robbed from the previous two houses and the current house, respectively.
2. Start iterating from the first house to the last house:
- Calculate the maximum amount that can be robbed from the current house as `max(prev + current_house_value, curr)`.
- Update `prev` and `curr` accordingly.
3. Return `curr` as the maximum amount of money that can be robbed without alerting the police.
Time Complexity:
O(n), where n is the number of houses. We perform a single pass through the houses.
Space Complexity:
O(1), as we use only two variables (`prev` and `curr`) to store intermediate results.
*/
impl Solution {
pub fn rob(nums: Vec<i32>) -> i32 {
let (mut prev, mut curr) = (0, 0);
for &num in nums.iter() {
let temp = curr;
curr = curr.max(prev + num);
prev = temp;
}
curr
}
}