aboutsummaryrefslogtreecommitdiff
path: root/store/works/solutions/leetcode/cpp/213.cpp
blob: cd98f673533a0c9acb8b5fb65c4c2bc8f201bca7 (plain)
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
34
35
36
37
38
39
40
41
#include <vector>

using std::vector;

class Solution
{
public:
    int rob(vector<int> &nums)
    {
        int count = nums.size();
        if (count == 0)
            return 0;

        if (count == 1)
            return nums.front();

        int not_rob_prev = 0;
        int rob_prev = nums.front();
        int not_rob_prev_and_not_rob_first = 0;
        int rob_prev_and_not_rob_first = 0;

        for (int i = 1; i < count - 1; i++)
        {
            int not_rob_prev_cache = not_rob_prev;
            int not_rob_prev_and_not_rob_first_cache = not_rob_prev_and_not_rob_first;
            not_rob_prev = std::max(not_rob_prev_cache, rob_prev);
            rob_prev = std::max(not_rob_prev_cache + nums[i], not_rob_prev);
            not_rob_prev_and_not_rob_first = std::max(not_rob_prev_and_not_rob_first_cache, rob_prev_and_not_rob_first);
            rob_prev_and_not_rob_first = std::max(not_rob_prev_and_not_rob_first_cache + nums[i], not_rob_prev_and_not_rob_first);
        }

        // last houst
        {
            int not_rob_prev_and_not_rob_first_cache = not_rob_prev_and_not_rob_first;
            not_rob_prev_and_not_rob_first = std::max(not_rob_prev_and_not_rob_first_cache, rob_prev_and_not_rob_first);
            rob_prev_and_not_rob_first = std::max(not_rob_prev_and_not_rob_first_cache + nums[count - 1], not_rob_prev_and_not_rob_first);
        }

        return std::max(rob_prev, rob_prev_and_not_rob_first);
    }
};