在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

base case和備忘錄初始值怎么定?

jf_78858299 ? 來源:labuladong ? 作者:labuladong ? 2023-04-19 10:28 ? 次閱讀

很多讀者對動態(tài)規(guī)劃問題的 base case、備忘錄初始值等問題存在疑問。

本文就專門講一講這類問題,順便聊一聊怎么通過題目的蛛絲馬跡揣測出題人的小心思,輔助我們解題。

看下力扣第 931 題「下降路徑最小和」,輸入為一個n * n的二維數(shù)組matrix,請你計算從第一行落到最后一行,經(jīng)過的路徑和最小為多少。

函數(shù)簽名如下:

int minFallingPathSum(int[][] matrix);

就是說你可以站在matrix的第一行的任意一個元素,需要下降到最后一行。

每次下降,可以向下、向左下、向右下三個方向移動一格。也就是說,可以從matrix[i][j]降到matrix[i+1][j]matrix[i+1][j-1]matrix[i+1][j+1]三個位置。

請你計算下降的「最小路徑和」,比如說題目給了一個例子:

圖片

今天這道題也是類似的,不算是困難的題目,所以 我們借這道題來講講 base case 的返回值、備忘錄的初始值、索引越界情況的返回值如何確定

不過還是要通過 動態(tài)規(guī)劃的標準套路介紹一下這道題的解題思路,首先我們可以定義一個dp數(shù)組:

int dp(int[][] matrix, int i, int j);

這個dp函數(shù)的含義如下:

從第一行(matrix[0][..])向下落,落到位置matrix[i][j]的最小路徑和為dp(matrix, i, j)

根據(jù)這個定義,我們可以把主函數(shù)的邏輯寫出來:

public int minFallingPathSum(int[][] matrix) {
    int n = matrix.length;
    int res = Integer.MAX_VALUE;

    // 終點可能在最后一行的任意一列
    for (int j = 0; j < n; j++) {
        res = Math.min(res, dp(matrix, n - 1, j));
    }

    return res;
}

因為我們可能落到最后一行的任意一列,所以要窮舉一下,看看落到哪一列才能得到最小的路徑和。

接下來看看dp函數(shù)如何實現(xiàn)。

對于matrix[i][j],只有可能從matrix[i-1][j], matrix[i-1][j-1], matrix[i-1][j+1]這三個位置轉(zhuǎn)移過來。

圖片

那么,只要知道到達(i-1, j), (i-1, j-1), (i-1, j+1)這三個位置的最小路徑和,加上matrix[i][j]的值,就能夠計算出來到達位置(i, j)的最小路徑和

int dp(int[][] matrix, int i, int j) {
    // 非法索引檢查
    if (i < 0 || j < 0 ||
        i >= matrix.length ||
        j >= matrix[0].length) {
        // 返回一個特殊值
        return 99999;
    }
    // base case
    if (i == 0) {
        return matrix[i][j];
    }
    // 狀態(tài)轉(zhuǎn)移
    return matrix[i][j] + min(
            dp(matrix, i - 1, j), 
            dp(matrix, i - 1, j - 1),
            dp(matrix, i - 1, j + 1)
        );
}

int min(int a, int b, int c) {
    return Math.min(a, Math.min(b, c));
}

當然,上述代碼是暴力窮舉解法,我們可以用備忘錄的方法消除重疊子問題,完整代碼如下:

public int minFallingPathSum(int[][] matrix) {
    int n = matrix.length;
    int res = Integer.MAX_VALUE;
    // 備忘錄里的值初始化為 66666
    memo = new int[n][n];
    for (int i = 0; i < n; i++) {
        Arrays.fill(memo[i], 66666);
    }
    // 終點可能在 matrix[n-1] 的任意一列
    for (int j = 0; j < n; j++) {
        res = Math.min(res, dp(matrix, n - 1, j));
    }
    return res;
}

// 備忘錄
int[][] memo;

int dp(int[][] matrix, int i, int j) {
    // 1、索引合法性檢查
    if (i < 0 || j < 0 ||
        i >= matrix.length ||
        j >= matrix[0].length) {

        return 99999;
    }
    // 2、base case
    if (i == 0) {
        return matrix[0][j];
    }
    // 3、查找備忘錄,防止重復計算
    if (memo[i][j] != 66666) {
        return memo[i][j];
    }
    // 進行狀態(tài)轉(zhuǎn)移
    memo[i][j] = matrix[i][j] + min(
            dp(matrix, i - 1, j), 
            dp(matrix, i - 1, j - 1),
            dp(matrix, i - 1, j + 1)
        );

    return memo[i][j];
}

int min(int a, int b, int c) {
    return Math.min(a, Math.min(b, c));
}

如果看過我們公眾號之前的動態(tài)規(guī)劃系列文章,這個解題思路應該是非常容易理解的。

那么本文對于這個dp函數(shù)仔細探討三個問題

1、對于索引的合法性檢測,返回值為什么是 99999?其他的值行不行?

2、base case 為什么是i == 0

3、備忘錄memo的初始值為什么是 66666?其他值行不行?

首先,說說 base case 為什么是i == 0,返回值為什么是matrix[0][j],這是根據(jù)dp函數(shù)的定義所決定的

回顧我們的dp函數(shù)定義:

從第一行(matrix[0][..])向下落,落到位置matrix[i][j]的最小路徑和為dp(matrix, i, j)

根據(jù)這個定義,我們就是從matrix[0][j]開始下落。那如果我們想落到的目的地就是i == 0,所需的路徑和當然就是matrix[0][j]唄。

再說說備忘錄memo的初始值為什么是 66666,這是由題目給出的數(shù)據(jù)范圍決定的

備忘錄memo數(shù)組的作用是什么?

就是防止重復計算,將dp(matrix, i, j)的計算結(jié)果存進memo[i][j],遇到重復計算可以直接返回。

那么,我們必須要知道memo[i][j]到底存儲計算結(jié)果沒有,對吧?如果存結(jié)果了,就直接返回;沒存,就去遞歸計算。

所以,memo的初始值一定得是特殊值,和合法的答案有所區(qū)分。

我們回過頭看看題目給出的數(shù)據(jù)范圍:

matrixn * n的二維數(shù)組,其中1 <= n <= 100;對于二維數(shù)組中的元素,有-100 <= matrix[i][j] <= 100

假設matrix的大小是 100 x 100,所有元素都是 100,那么從第一行往下落,得到的路徑和就是 100 x 100 = 10000,也就是最大的合法答案。

類似的,依然假設matrix的大小是 100 x 100,所有元素是 -100,那么從第一行往下落,就得到了最小的合法答案 -100 x 100 = -10000。

也就是說,這個問題的合法結(jié)果會落在區(qū)間[-10000, 10000]中。

所以,我們memo的初始值就要避開區(qū)間[-10000, 10000],換句話說,memo的初始值只要在區(qū)間(-inf, -10001] U [10001, +inf)中就可以。

最后,說說對于不合法的索引,返回值應該如何確定,這需要根據(jù)我們狀態(tài)轉(zhuǎn)移方程的邏輯確定

對于這道題,狀態(tài)轉(zhuǎn)移的基本邏輯如下:

int dp(int[][] matrix, int i, int j) {

    return matrix[i][j] + min(
            dp(matrix, i - 1, j), 
            dp(matrix, i - 1, j - 1),
            dp(matrix, i - 1, j + 1)
        );
}

顯然,i - 1, j - 1, j + 1這幾個運算可能會造成索引越界,對于索引越界的dp函數(shù),應該返回一個不可能被取到的值。

因為我們調(diào)用的是min函數(shù),最終返回的值是最小值,所以對于不合法的索引,只要dp函數(shù)返回一個永遠不會被取到的最大值即可。

剛才說了,合法答案的區(qū)間是[-10000, 10000],所以我們的返回值只要大于 10000 就相當于一個永不會取到的最大值。

換句話說,只要返回區(qū)間[10001, +inf)中的一個值,就能保證不會被取到。

至此,我們就把動態(tài)規(guī)劃相關的三個細節(jié)問題舉例說明了。

拓展延伸一下,建議大家做題時,除了題意本身,一定不要忽視題目給定的其他信息

本文舉的例子,測試用例數(shù)據(jù)范圍可以確定「什么是特殊值」,從而幫助我們將思路轉(zhuǎn)化成代碼。

除此之外,數(shù)據(jù)范圍還可以幫我們估算算法的時間/空間復雜度。

比如說,有的算法題,你只想到一個暴力求解思路,時間復雜度比較高。如果發(fā)現(xiàn)題目給定的數(shù)據(jù)量比較大,那么肯定可以說明這個求解思路有問題或者存在優(yōu)化的空間。

除了數(shù)據(jù)范圍,有時候題目還會限制我們算法的時間復雜度,這種信息其實也暗示著一些東西。

比如要求我們的算法復雜度是O(NlogN),你想想怎么才能搞出一個對數(shù)級別的復雜度呢?

肯定得用到 二分搜索或者二叉樹相關的數(shù)據(jù)結(jié)構(gòu),比如TreeMapPriorityQueue之類的對吧。

再比如,有時候題目要求你的算法時間復雜度是O(MN),這可以聯(lián)想到什么?

可以大膽猜測,常規(guī)解法是用 [回溯算法暴力窮舉,但是更好的解法是動態(tài)規(guī)劃,而且是一個二維動態(tài)規(guī)劃,需要一個M * N的二維dp數(shù)組,所以產(chǎn)生了這樣一個時間復雜度。

如果你早就胸有成竹了,那就當我沒說,畢竟猜測也不一定準確;但如果你本來就沒啥解題思路,那有了這些推測之后,最起碼可以給你的思路一些方向吧?

總之,多動腦筋,不放過任何蛛絲馬跡,你不成為刷題小能手才怪。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
收藏 人收藏

    評論

    相關推薦

    恩智浦與Cohda無線簽署CAR 2 CAR通信聯(lián)盟“諒解備忘錄

    恩智浦半導體和Cohda的無線今天宣布,他們已經(jīng)簽署的CAR 2 CAR通信聯(lián)盟”諒解備忘錄”(MOU)。該備忘錄旨在確保歐洲車與車之間,或是汽車和交通基礎設施間,無線通訊科技技術(shù)的實施和統(tǒng)一
    發(fā)表于 04-17 10:10 ?923次閱讀

    HarmonyOS開發(fā)實例:【手機備忘錄

    基于用戶首選項,實現(xiàn)了備忘錄新增、更新、刪除以及查找等功能。
    的頭像 發(fā)表于 04-18 21:40 ?830次閱讀
    HarmonyOS開發(fā)實例:【手機<b class='flag-5'>備忘錄</b>】

    PostgreSQL操作備忘錄

    PostgreSQL 操作備忘錄
    發(fā)表于 05-23 08:48

    UDS診斷命令備忘錄

    UDS實踐性強,邏輯復雜,很多服務非要體驗過一次才能理解,導致包括我在內(nèi)的初學者感覺晦澀難懂,不明覺厲,因此將自己的理解寫下來、整理下來,與君共勉。零、UDS診斷命令備忘錄一、簡介UDS
    發(fā)表于 08-26 16:09

    怎樣去搭建一種基于XR806的開源桌面備忘錄

    本人計劃懟一個開源桌面備忘錄/天氣預報/相冊的項目基于XR806,同時學習鴻蒙操作系統(tǒng)獲得暈哥贈送的開發(fā)板和芯片,目前處于環(huán)境搭建階段看起來這個芯片玩的人比較少,目前遇到了問題,不知道如何解決,希望
    發(fā)表于 12-28 06:52

    換路定律及初始值的確定

    換路定律及初始值的確定:3.2 換路定律及初始值的確定3.2.1 換路定律通常,我們把電路中開關的接通、斷開或電路參數(shù)的突然變化等統(tǒng)稱為“換路”。我們研究的是換路后電
    發(fā)表于 05-10 00:04 ?30次下載

    全球半導體聯(lián)盟與中國半導體行業(yè)簽署合作備忘錄

    全球半導體聯(lián)盟與中國半導體行業(yè)簽署合作備忘錄 全球半導體聯(lián)盟(GSA)與中國半導體行業(yè)協(xié)會(CSIA)在蘇州聯(lián)合申明簽署合作備忘錄。此次合作將為促
    發(fā)表于 09-24 08:17 ?703次閱讀

    是德科技與中國移動簽署諒解備忘錄

    是德科技(NYSE:KEYS)今日宣布與中國移動通信集團有限公司(CMCC)簽署諒解備忘錄(MoU)將全力支持 5G 終端先行者計劃的實施。
    的頭像 發(fā)表于 07-19 11:01 ?4848次閱讀

    戴姆勒與百度簽署諒解備忘錄

    7月25日,奔馳母公司戴姆勒與百度簽署諒解備忘錄,深化雙方在自動駕駛和車聯(lián)網(wǎng)等領域的戰(zhàn)略合作。
    的頭像 發(fā)表于 07-28 09:53 ?2733次閱讀

    Vedanta與30家日本公司簽署諒解備忘錄

    印度Vedanta Group已與30家日本公司簽署諒解備忘錄,以開發(fā)印度半導體和玻璃顯示器制造生態(tài)系統(tǒng)。上周在日本東京舉行的2022年Vedanta-Avanstrate商業(yè)合作伙伴峰會上簽署了這些備忘錄,來自100多家全球公司的200多名代表出席了峰會。
    的頭像 發(fā)表于 12-15 09:12 ?987次閱讀

    設計模式:備忘錄設計模式

    備忘錄設計模式(Memento Design Pattern)是一種行為型設計模式,它的主要目的是在不破壞對象封裝性的前提下,捕捉和保存一個對象的內(nèi)部狀態(tài)
    的頭像 發(fā)表于 06-06 11:19 ?812次閱讀

    設計模式行為型:備忘錄模式

    備忘錄模式(Memento Pattern)保存一個對象的某個狀態(tài),以便在適當?shù)臅r候恢復對象。備忘錄模式屬于行為型模式。
    的頭像 發(fā)表于 06-07 11:16 ?866次閱讀
    設計模式行為型:<b class='flag-5'>備忘錄</b>模式

    新思科技同越南政府簽署諒解備忘錄

    在越南總理范明政訪美期間,新思科技與越南國家創(chuàng)新中心(nic)簽署了關于培養(yǎng)越南集成電路設計人才的諒解備忘錄,支持nic成立芯片設計孵化中心。另外,新思科技與越南信息通訊部下屬的信息通信技術(shù)產(chǎn)業(yè)公司簽訂了支援越南半導體產(chǎn)業(yè)發(fā)展的諒解備忘錄
    的頭像 發(fā)表于 09-20 10:56 ?1566次閱讀

    實踐GoF的23種設計模式:備忘錄模式

    相對于代理模式、工廠模式等設計模式,備忘錄模式(Memento)在我們?nèi)粘i_發(fā)中出鏡率并不高,除了應用場景的限制之外,另一個原因,可能是備忘錄模式
    的頭像 發(fā)表于 11-25 09:05 ?561次閱讀
    實踐GoF的23種設計模式:<b class='flag-5'>備忘錄</b>模式

    蘋果iOS 18將支持語音備忘錄及數(shù)學符號顯示

    首先是語音備忘錄功能。據(jù)悉,蘋果有意在iOS 18系統(tǒng)中加入此項功能,使iPhone用戶能夠便捷地錄制音頻文件,并將其直接嵌入至備忘錄之中。
    的頭像 發(fā)表于 04-18 11:14 ?545次閱讀
    主站蜘蛛池模板: 色干干| mm365快播综合网| 俺去久久| chinese国产videoxx实拍| www.av在线.com| 9999毛片免费看| 国产精品丝袜在线观看| 亚洲第一视频区| 最近2018年中文字幕在线| 综合色吧| 四虎在线视频| 女人张开双腿让男人桶完整| 久久黄网站| 你懂的在线观看网址| 六月婷操| 国产精品日韩欧美亚洲另类| 在线免费看片a| 日本一本一道久久香蕉免费| 成人影院在线观看视频| 综合欧美一区二区三区| 狠狠干狠狠色| 色婷婷综合久久久中文字幕| 性欧美大战久久久久久久| 中文字幕卡二和卡三的视频| 午夜久久免影院欧洲| 欧美性淫爽www视频播放| 国模在线视频| 韩国电影天堂| aaa特级毛片| 欧美午夜性春猛交bbb| 国产黄色片在线观看| aaaaa国产毛片| 色狠狠狠狠综合影视| 国产一区二区三区在线影院| 午夜精品aaa国产福利| 夜性影院| 亚洲视频在线一区二区三区| 性夜影院爽黄a爽免费视| 亚洲色图吧| 男人的天堂一区二区视频在线观看 | 国产精品九九久久一区hh |