213 打家劫舍 II

2021-10-01 07:55:38 字數 489 閱讀 3787

比198那個題就是增加了首位相連的限制。由於首尾不能同時偷,也就是掐頭和去尾得到兩個鍊錶,分別計算出最大金額去最大值。

class solution:

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

def my_rob(nums):

cur, pre = 0, 0

for num in nums:

cur, pre = max(pre + num, cur), cur

return cur

return max(my_rob(nums[:-1]),my_rob(nums[1:])) if len(nums) != 1 else nums[0]

用cur和pre表示今天和昨天,要求明天。簡化了之前的狀態轉移方程形式。

213 打家劫舍 II

題目描述提示幫助提交記錄社群討論閱讀解答 你是乙個專業的小偷,計畫偷竊沿街的房屋,每間房內都藏有一定的現金。這個地方所有的房屋都圍成一圈,這意味著第乙個房屋和最後乙個房屋是緊挨著的。同時,相鄰的房屋裝有相互連通的防盜系統,如果兩間相鄰的房屋在同一晚上被小偷闖入,系統會自動報警。給定乙個代表每個房屋存...

213 打家劫舍 II

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

213 打家劫舍 II

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