LeetCode 213 打家劫舍 II

2022-03-26 04:45:46 字數 1426 閱讀 4359

difficulty:中等

你是乙個專業的小偷,計畫偷竊沿街的房屋,每間房內都藏有一定的現金。這個地方所有的房屋都圍成一圈,這意味著第乙個房屋和最後乙個房屋是緊挨著的。同時,相鄰的房屋裝有相互連通的防盜系統,如果兩間相鄰的房屋在同一晚上被小偷闖入,系統會自動報警

給定乙個代表每個房屋存放金額的非負整數陣列,計算你在不觸動警報裝置的情況下,能夠偷竊到的最高金額。

示例 1:

輸入:nums = [2,3,2]

輸出:3

解釋:你不能先偷竊 1 號房屋(金額 = 2),然後偷竊 3 號房屋(金額 = 2), 因為他們是相鄰的。

示例 2:

輸入:nums = [1,2,3,1]

輸出:4

解釋:你可以先偷竊 1 號房屋(金額 = 1),然後偷竊 3 號房屋(金額 = 3)。

偷竊到的最高金額 = 1 + 3 = 4 。

示例 3:

輸入:nums = [0]

輸出:0

solution

這道題是leetcode 198. 打家劫舍 - swordspoet - 的乙個變種,只是題目說明首尾兩家是相鄰的,不能同時被搶,但是可以搶其中的一家。所以我們可以把搶劫分成兩種情況,一種不包含最後一家,一種不包含第一家,然後分別計算這兩種情形下能夠搶的金額,最後兩者取最大值即可。

需要注意還有一種特殊情況:就是只有一家的情況下直接返回就可以了,第一次提交沒有注意這個情況提交錯誤。

class solution:

def rob(self, nums: list[int]) -> int:

# 首位不能同時搶,那麼把首尾分開,分成兩種情況討論

if not nums:

return 0

if len(nums) == 1:

return nums[0]

nums1, nums2 = nums[1:], nums[:-1]

return max(self.robhelper(nums1), self.robhelper(nums2))

def robhelper(self, nums):

dp = [0] * (len(nums) + 1)

dp[0], dp[1] = 0, nums[0]

for i in range(2, len(nums)+1):

dp[i] = max(dp[i-2] + nums[i-1], dp[i-1])

return dp[len(nums)]

leetcode213 打家劫舍

難度簡單683收藏分享切換為英文關注反饋你是乙個專業的小偷,計畫偷竊沿街的房屋。每間房內都藏有一定的現金,影響你偷竊的唯一制約因素就是相鄰的房屋裝有相互連通的防盜系統,如果兩間相鄰的房屋在同一晚上被小偷闖入,系統會自動報警。給定乙個代表每個房屋存放金額的非負整數陣列,計算你在不觸動警報裝置的情況下,...

LeetCode 213 打家劫舍

很明顯該題目的難度在於首尾相連,而198題的打家劫舍是單排列,首尾相連如何理解?首尾相連意味著第乙個和最後乙個房屋只能選擇偷乙個,即偷第乙個房屋不偷最後乙個房屋,或者不偷第乙個房屋偷最後乙個房屋。所以該問題就能分解成兩個單排列的問題。問題1 偷第乙個房屋不偷最後乙個房屋,偷取範圍為 0 n 2,問題...

leetcode213打家劫舍II

打家劫舍ii 問題描述 在上次盜竊完一條街道之後,竊賊又轉到了乙個新的地方,這樣他就不會引起太多注意。這一次,這個地方的所有房屋都圍成一圈。這意味著第乙個房子是最後乙個是緊挨著的。同時,這些房屋的安全系統與上次那條街道的安全系統保持一致。給出乙份代表每個房屋存放錢數的非負整數列表,確定你可以在不觸動...