你是乙個專業的小偷,計畫偷竊沿街的房屋。每間房內都藏有一定的現金,影響你偷竊的唯一制約因素就是相鄰的房屋裝有相互連通的防盜系統,如果兩間相鄰的房屋在同一晚上被小偷闖入,系統會自動報警。
給定乙個代表每個房屋存放金額的非負整數陣列,計算你在不觸動警報裝置的情況下,能夠偷竊到的最高金額。
示例 1:
輸入:[1,2,3,1]輸出:4解釋:偷竊 1 號房屋 (金額 = 1) ,然後偷竊 3 號房屋 (金額 = 3)。示例 2:偷竊到的最高金額 = 1 + 3 = 4 。
輸入:[2,7,9,3,1]輸出:12解釋:偷竊 1 號房屋 (金額 = 2), 偷竊 3 號房屋 (金額 = 9),接著偷竊 5 號房屋 (金額 = 1)。一道典型的dp題,當前下標i下的金額只能和i-2下標下的金額做和,是這道題的乙個小的限制,始終是為了維護dp陣列,dp的意義是前i家房屋的所能打劫到的最大值。偷竊到的最高金額 = 2 + 9 + 1 = 12 。
class solution
int dp = new int[nums.length+1];
dp[0] = 0;
dp[1] = nums[0];
for(int i=1;ireturn dp[nums.length];
}}
LeetCode 打家劫舍
你是乙個專業的小偷,計畫偷竊沿街的房屋。每間房內都藏有一定的現金,影響你偷竊的唯一制約因素就是相鄰的房屋裝有相互連通的防盜系統,如果兩間相鄰的房屋在同一晚上被小偷闖入,系統會自動報警。給定乙個代表每個房屋存放金額的非負整數陣列,計算你在不觸動警報裝置的情況下,能夠偷竊到的最高金額。示例 1 輸入 1...
leetcode 打家劫舍
你是乙個專業的小偷,計畫偷竊沿街的房屋。每間房內都藏有一定的現金,影響你偷竊的唯一制約因素就是相鄰的房屋裝有相互連通的防盜系統,如果兩間相鄰的房屋在同一晚上被小偷闖入,系統會自動報警。給定乙個代表每個房屋存放金額的非負整數陣列,計算你在不觸動警報裝置的情況下,能夠偷竊到的最高金額。示例 1 輸入 1...
leetcode 打家劫舍
動態規劃 dp i 表示到第i個房屋的偷竊最高金額。顯然,遞推公式為 dp i max dp i 2 nums i 1 dp i 1 含義為,當前房屋的最高金額為前前個房屋的最高金額加上當前房屋的財富和上乙個房屋的最高偷竊金額中的最大值 1 特判,若陣列為空,返回0 2 初始化dp 0,0 為n 1...