New Problem "House Robber II"
This commit is contained in:
parent
98ffa55553
commit
0b5710948d
@ -7,6 +7,7 @@ LeetCode
|
|||||||
|
|
||||||
| # | Title | Solution | Difficulty |
|
| # | Title | Solution | Difficulty |
|
||||||
|---| ----- | -------- | ---------- |
|
|---| ----- | -------- | ---------- |
|
||||||
|
|197|[House Robber II](https://leetcode.com/problems/house-robber-ii/)| [C++](./algorithms/houseRobber/houseRobber.II.cpp)|Medium|
|
||||||
|196|[Word Search II](https://leetcode.com/problems/word-search-ii/)| [C++](./algorithms/wordSearch/wordSearch.II.cpp)|Hard|
|
|196|[Word Search II](https://leetcode.com/problems/word-search-ii/)| [C++](./algorithms/wordSearch/wordSearch.II.cpp)|Hard|
|
||||||
|195|[Add and Search Word - Data structure design](https://leetcode.com/problems/add-and-search-word-data-structure-design/)| [C++](./algorithms/addAndSearchWord/AddAndSearchWord.cpp)|Medium|
|
|195|[Add and Search Word - Data structure design](https://leetcode.com/problems/add-and-search-word-data-structure-design/)| [C++](./algorithms/addAndSearchWord/AddAndSearchWord.cpp)|Medium|
|
||||||
|194|[Course Schedule II](https://leetcode.com/problems/course-schedule-ii/)| [C++](./algorithms/courseSchedule/CourseSchedule.II.cpp)|Medium|
|
|194|[Course Schedule II](https://leetcode.com/problems/course-schedule-ii/)| [C++](./algorithms/courseSchedule/CourseSchedule.II.cpp)|Medium|
|
||||||
|
57
algorithms/houseRobber/houseRobber.II.cpp
Normal file
57
algorithms/houseRobber/houseRobber.II.cpp
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
// Source : https://leetcode.com/problems/house-robber-ii/
|
||||||
|
// Author : Hao Chen
|
||||||
|
// Date : 2015-06-10
|
||||||
|
|
||||||
|
/**********************************************************************************
|
||||||
|
*
|
||||||
|
* Note: This is an extension of House Robber.
|
||||||
|
*
|
||||||
|
* After robbing those houses on that street, the thief has found himself a new place
|
||||||
|
* for his thievery so that he will not get too much attention. This time, all houses
|
||||||
|
* at this place are arranged in a circle. That means the first house is the neighbor
|
||||||
|
* of the last one. Meanwhile, the security system for these houses remain the same as
|
||||||
|
* for those in the previous street.
|
||||||
|
*
|
||||||
|
* 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 @Freezen for adding this problem and creating all test cases.
|
||||||
|
*
|
||||||
|
**********************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
class Solution {
|
||||||
|
public:
|
||||||
|
int orginal_rob(vector<int> &money, int start, int end) {
|
||||||
|
int n2=0;
|
||||||
|
int n1=0;
|
||||||
|
|
||||||
|
for (int i=start; i<end; i++){
|
||||||
|
int current = max(n1, n2 + money[i]);
|
||||||
|
n2 = n1;
|
||||||
|
n1 = current;
|
||||||
|
}
|
||||||
|
return n1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int rob(vector<int>& nums) {
|
||||||
|
int n = nums.size();
|
||||||
|
switch (n) {
|
||||||
|
case 0:
|
||||||
|
return 0;
|
||||||
|
case 1:
|
||||||
|
return nums[0];
|
||||||
|
case 2:
|
||||||
|
return max(nums[0], nums[1]);
|
||||||
|
default:
|
||||||
|
/*
|
||||||
|
* the idea is we cannot rob[0] and rob[n-1] at same time
|
||||||
|
* so, we rob [0 .. n-2] or [1 .. n-1], can return the maxinum one.
|
||||||
|
*/
|
||||||
|
int m1 = orginal_rob(nums, 0, n-1);
|
||||||
|
int m2 = orginal_rob(nums, 1, n);
|
||||||
|
|
||||||
|
return max(m1, m2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
Loading…
x
Reference in New Issue
Block a user