成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

LeetCode 213. 打家劫舍 II【c++/java詳細(xì)題解】

Kyxy / 2860人閱讀

摘要:給定一個(gè)代表每個(gè)房屋存放金額的非負(fù)整數(shù)數(shù)組,計(jì)算你在不觸動(dòng)警報(bào)裝置的情況下,今晚能夠偷竊到的最高金額。狀態(tài)表示表示偷竊號(hào)到號(hào)房間所能獲得的最高金額。下標(biāo)均從開始打家劫舍我們已經(jīng)知道了房間單排排列的狀態(tài)轉(zhuǎn)移方程,接下來思考房間環(huán)狀排列的做法。

1、題目

你是一個(gè)專業(yè)的小偷,計(jì)劃偷竊沿街的房屋,每間房?jī)?nèi)都藏有一定的現(xiàn)金。這個(gè)地方所有的房屋都 圍成一圈 ,這意味著第一個(gè)房屋和最后一個(gè)房屋是緊挨著的。同時(shí),相鄰的房屋裝有相互連通的防盜系統(tǒng),如果兩間相鄰的房屋在同一晚上被小偷闖入,系統(tǒng)會(huì)自動(dòng)報(bào)警 。

給定一個(gè)代表每個(gè)房屋存放金額的非負(fù)整數(shù)數(shù)組,計(jì)算你 在不觸動(dòng)警報(bào)裝置的情況下 ,今晚能夠偷竊到的最高金額。

示例 1:

輸入:nums = [2,3,2]輸出:3解釋:你不能先偷竊 1 號(hào)房屋(金額 = 2),然后偷竊 3 號(hào)房屋(金額 = 2), 因?yàn)樗麄兪窍噜彽摹?/code>

示例 2:

輸入:nums = [1,2,3,1]輸出:4解釋:你可以先偷竊 1 號(hào)房屋(金額 = 1),然后偷竊 3 號(hào)房屋(金額 = 3)。     偷竊到的最高金額 = 1 + 3 = 4 。

示例 3:

輸入:nums = [0]輸出:0

2、思路

給定一個(gè)代表金額的非負(fù)整數(shù)數(shù)組nums,相鄰房間不可偷并且房間是圍成一圈的,讓我們輸出可以偷竊到的最高金額。

樣例:

如樣例所示,nums = [1,2,3,1],偷竊1,3,號(hào)房間可以獲得最高金額4

打家劫舍 I

我們先來看看「198. 打家劫舍」房間單排排列的動(dòng)態(tài)規(guī)劃的做法。

狀態(tài)表示:f[i]表示偷竊1號(hào)到i號(hào)房間所能獲得的最高金額。那么,f[n]就表示偷竊1號(hào)到n號(hào)房間所能獲得的最高金額,即為答案。

狀態(tài)計(jì)算:

假設(shè)有i間房間,考慮最后一間偷還是不偷房間,有兩種選擇方案:

  • 1、偷竊前i-1間房間,不偷竊最后一間房間,那么問題就轉(zhuǎn)化為了偷竊1號(hào)到i- 1號(hào)房間所能獲得的最高金額,即f[i] = f[i-1]。
  • 2、偷竊前i - 2間房間和最后一間房間 (相鄰的房屋不可闖入),那么問題就轉(zhuǎn)化為了偷竊1號(hào)到i- 2號(hào)房間所能獲得的最高金額再加上偷竊第i號(hào)房間的金額,即f[i] = f[i - 2] + nums[i]。 (下標(biāo)均從1開始)

兩種方案,選擇其中金額最大的一個(gè)。因此狀態(tài)轉(zhuǎn)移方程為: f[i] = max(f[i - 1], f[i - 2] + nums[i])。 (下標(biāo)均從1開始)

打家劫舍 II

我們已經(jīng)知道了房間單排排列的狀態(tài)轉(zhuǎn)移方程,接下來思考房間環(huán)狀排列的做法。

房間環(huán)狀排列 意味著第一間和最后一間不能同時(shí)選擇,因此我們可以分成兩種情況來討論:

  • 1、不偷竊最后一間房間,那么問題轉(zhuǎn)化為偷竊1號(hào)到i - 1號(hào)房間所能獲得的最高金額。
  • 2、不偷竊第一間房間,那么問題轉(zhuǎn)化為偷竊2號(hào)到i號(hào)房間所能獲得的最高金額。

兩種情況中取最大值,這樣我們就把環(huán)狀排列問題轉(zhuǎn)化為了兩個(gè)單排排列的子問題。

我們定義兩個(gè)數(shù)組f[]g[],分別用f[n-1]g[n]兩個(gè)數(shù)組值來表示區(qū)間[1, n - 1][2, n]的最大金額值,圖示過程如下:

初始化:

f[1] = nums[0],只偷竊1號(hào)房間所能獲得的最高金額為nums[0]

g[2] = nums[1],把第二間房間當(dāng)成房間單排排列的起點(diǎn),只偷竊2號(hào)房間所能獲得的最高金額為nums[1]。

實(shí)現(xiàn)細(xì)節(jié):

我們定義的狀態(tài)表示f[]g[]數(shù)組以及nums[]數(shù)組下標(biāo)均是從1開始的,而題目給出的nums[]數(shù)組下標(biāo)是從0開始的。為了一 一對(duì)應(yīng),狀態(tài)轉(zhuǎn)移方程中的nums[i]的值要往前錯(cuò)一位,取nums[i - 1],這點(diǎn)細(xì)節(jié)希望大家可以注意一下。

時(shí)間復(fù)雜度分析: O ( n ) O(n) O(n),其中 n n n是數(shù)組長(zhǎng)度。需要對(duì)數(shù)組遍歷一次。

3、c++代碼

class Solution {public:    int rob(vector<int>& nums) {       int n = nums.size();       if(n == 1) return nums[0];       //只有一間房間,返回nums[0]       vector<int>f(n + 1), g(n + 1);       f[1] = nums[0], g[2] = nums[1];  //初始化       for(int i = 2; i <= n - 1; i++)  f[i] = max(f[i - 1], f[i - 2] + nums[i - 1]); //區(qū)間[1,n-1]最大值       for(int i = 3; i <= n; i++)      g[i] = max(g[i - 1], g[i - 2] + nums[i - 1]); //區(qū)間[2,n]最大值       return max(f[n - 1], g[n]);    }};

4、java代碼

class Solution {    public int rob(int[] nums) {       int n = nums.length;       if(n == 1) return nums[0];     //只有一間房間,返回nums[0]       int[] f = new int[n + 1],  g = new int[n + 1];       f[1] = nums[0];    //初始化       g[2] = nums[1];           for(int i = 2; i <= n - 1; i++) f[i] = Math.max(f[i - 1], f[i - 2] + nums[i - 1]);       for(int i = 3; i <= n; i++)     g[i] = Math.max(g[i - 1], g[i - 2] + nums[i - 1]);       return Math.max(f[n - 1], g[n]);    }}

原題鏈接:213. 打家劫舍 II

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/120811.html

相關(guān)文章

  • 【算法解析LeetCode by Javascript】213. 打家劫舍 II

    摘要:偷竊到的最高金額。世紀(jì)年代初美國(guó)數(shù)學(xué)家等人在研究多階段決策過程的優(yōu)化問題時(shí),提出了著名的最優(yōu)化原理,把多階段過程轉(zhuǎn)化為一系列單階段問題,利用各階段之間的關(guān)系,逐個(gè)求解,創(chuàng)立了解決這類過程優(yōu)化問題的新方法動(dòng)態(tài)規(guī)劃。 showImg(https://segmentfault.com/img/bVbplM3?w=953&h=465); 題目描述 你是一個(gè)專業(yè)的小偷,計(jì)劃偷竊沿街的房屋,每間房...

    crelaber 評(píng)論0 收藏0
  • LeetCode 攻略 - 2019 年 7 月上半月匯總(55 題攻略)

    摘要:微信公眾號(hào)記錄截圖記錄截圖目前關(guān)于這塊算法與數(shù)據(jù)結(jié)構(gòu)的安排前。已攻略返回目錄目前已攻略篇文章。會(huì)根據(jù)題解以及留言內(nèi)容,進(jìn)行補(bǔ)充,并添加上提供題解的小伙伴的昵稱和地址。本許可協(xié)議授權(quán)之外的使用權(quán)限可以從處獲得。 Create by jsliang on 2019-07-15 11:54:45 Recently revised in 2019-07-15 15:25:25 一 目錄 不...

    warmcheng 評(píng)論0 收藏0
  • LeetCode 攻略 - 2019 年 7 月下半月匯總(100 題攻略)

    摘要:月下半旬攻略道題,目前已攻略題。目前簡(jiǎn)單難度攻略已經(jīng)到題,所以后面會(huì)調(diào)整自己,在刷算法與數(shù)據(jù)結(jié)構(gòu)的同時(shí),攻略中等難度的題目。 Create by jsliang on 2019-07-30 16:15:37 Recently revised in 2019-07-30 17:04:20 7 月下半旬攻略 45 道題,目前已攻略 100 題。 一 目錄 不折騰的前端,和咸魚有什么區(qū)別...

    tain335 評(píng)論0 收藏0
  • 前端 | 每天一個(gè) LeetCode

    摘要:在線網(wǎng)站地址我的微信公眾號(hào)完整題目列表從年月日起,每天更新一題,順序從易到難,目前已更新個(gè)題。這是項(xiàng)目地址歡迎一起交流學(xué)習(xí)。 這篇文章記錄我練習(xí)的 LeetCode 題目,語(yǔ)言 JavaScript。 在線網(wǎng)站:https://cattle.w3fun.com GitHub 地址:https://github.com/swpuLeo/ca...我的微信公眾號(hào): showImg(htt...

    張漢慶 評(píng)論0 收藏0
  • LeetCode - 013 - 羅馬數(shù)字轉(zhuǎn)整數(shù)(roman-to-integer)

    摘要:字符數(shù)值例如,羅馬數(shù)字寫做,即為兩個(gè)并列的。通常情況下,羅馬數(shù)字中小的數(shù)字在大的數(shù)字的右邊。給定一個(gè)羅馬數(shù)字,將其轉(zhuǎn)換成整數(shù)。 Create by jsliang on 2019-05-23 13:24:24 Recently revised in 2019-05-23 14:55:20 一 目錄 不折騰的前端,和咸魚有什么區(qū)別 目錄 一 目錄 二 前言 三 解題 ...

    v1 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<