-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Copy pathHouse_Robber.py
61 lines (45 loc) · 1.98 KB
/
House_Robber.py
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#A thief wants to loot houses. He knows the amount of money in each house. He cannot loot two consecutive houses. Find the maximum amount of money he can loot.
def maxMoneyLooted(amountInHouses, totalHouses) :
#If there are 0 houses , return 0
if totalHouses == 0 :
return 0
#If there is only one house , return its money
if totalHouses == 1 :
return amountInHouses[0]
#If there are atleast 2 houses ,create arr and calculate the maximum amount of money that can be looted
maxMoneyCanBeLooted = [0]*totalHouses
maxMoneyCanBeLooted[0] = amountInHouses[0]
maxMoneyCanBeLooted[1] = max(amountInHouses[0], amountInHouses[1])
for currHouse in range(2,totalHouses) :
#At each i th house either (houses upto i-2) + (i th house) or (houses upto i-1) can be robbed
maxMoneyCanBeLooted[currHouse] = max(maxMoneyCanBeLooted[currHouse - 1], (amountInHouses[currHouse] + maxMoneyCanBeLooted[currHouse - 2]))
#Return the required answer which is the maximum amount of money that can be robbed till last house
return maxMoneyCanBeLooted[totalHouses-1]
def takeInput() :
n = int(input().rstrip())
if n == 0 :
return list(), 0
arr = list(map(int, input().rstrip().split(" ")))
return arr, n
def main():
print('Enter total number of houses and amount that each house contains: ')
amountInHouses,totalHouses = takeInput()
print('Maximum amount that can be taken be the thief is: ')
print(maxMoneyLooted(amountInHouses,totalHouses))
if __name__ == '__main__':
main()
'''
Time Complexity: O(n)
Space Complexity: O(n)
where n is the total number of houses
Sample Input:
Enter total number of houses and amount that each house contains:
6
10 2 30 20 3 50
Sample Output:
Maximum amount that can be taken be the thief is:
90
Explanation :
Looting first, third, and the last houses([10 + 30 + 50]) will result in the maximum loot,
and all the other possible combinations would result in less than 90.
'''