64. 最小路徑和

題目


https://leetcode-cn.com/problems/minimum-path-sum/
給定一個(gè)包含非負(fù)整數(shù)的 m x n 網(wǎng)格,請(qǐng)找出一條從左上角到右下角的路徑吏垮,使得路徑上的數(shù)字總和為最小障涯。

說明:每次只能向下或者向右移動(dòng)一步。
難度:中等


思路


1.動(dòng)態(tài)規(guī)劃膳汪,開辟一個(gè)mxn的數(shù)組唯蝶,存儲(chǔ)當(dāng)前的最小值,最小值實(shí)際就是左和上兩者中小較小的加上當(dāng)前的值遗嗽。
2.由于每個(gè)用過的元素不會(huì)二次使用粘我,因此可以直接更新當(dāng)前的數(shù)組,不用新開辟痹换,可以節(jié)省內(nèi)存


解法


1.動(dòng)態(tài)規(guī)劃征字。

//leetcode submit region begin(Prohibit modification and deletion)
class minPathSumx {
    public int minPathSum(int[][] grid) {
        if (grid == null || grid.length == 0 || grid[0].length == 0) {
            return 0;
        }

        int rows = grid.length, columns = grid[0].length;
        int[][] dp = new int[rows][columns];
        dp[0][0] = grid[0][0];
        for (int i = 1; i < rows; i++) {
            dp[i][0] = dp[i - 1][0] + grid[i][0];
        }
        for (int j = 1; j < columns; j++) {
            dp[0][j] = dp[0][j - 1] + grid[0][j];
        }
        for (int i = 1; i < rows; i++) {
            for (int j = 1; j < columns; j++) {
                dp[i][j] = Math.min(dp[i - 1][j], dp[i][j - 1]) + grid[i][j];
            }
        }
        return dp[rows - 1][columns - 1];
}
//leetcode submit region end(Prohibit modification and deletion)

2.動(dòng)態(tài)規(guī)劃都弹,不開辟dp。

//leetcode submit region begin(Prohibit modification and deletion)
class minPathSumx {
    public int minPathSum(int[][] grid) {
        for (int i = 0; i < rows; i++) {
            for (int j = 0; j < columns; j++) {
                if (0 == i && 0 == j) continue;
                else if (0 == i) grid[i][j] += grid[i][j - 1];
                else if (0 == j) grid[i][j] += grid[i - 1][j];
                else grid[i][j] += Math.min(grid[i - 1][j], grid[i][j - 1]);
            }
        }
        return grid[rows - 1][columns - 1];
}
//leetcode submit region end(Prohibit modification and deletion)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末匙姜,一起剝皮案震驚了整個(gè)濱河市畅厢,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌氮昧,老刑警劉巖框杜,帶你破解...
    沈念sama閱讀 221,695評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異郭计,居然都是意外死亡霸琴,警方通過查閱死者的電腦和手機(jī)椒振,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門昭伸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人澎迎,你說我怎么就攤上這事庐杨。” “怎么了夹供?”我有些...
    開封第一講書人閱讀 168,130評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵灵份,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我哮洽,道長(zhǎng)填渠,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,648評(píng)論 1 297
  • 正文 為了忘掉前任鸟辅,我火速辦了婚禮氛什,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘匪凉。我一直安慰自己,他們只是感情好再层,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著聂受,像睡著了一般蒿秦。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蛋济,一...
    開封第一講書人閱讀 52,268評(píng)論 1 309
  • 那天棍鳖,我揣著相機(jī)與錄音,去河邊找鬼瘫俊。 笑死鹊杖,一個(gè)胖子當(dāng)著我的面吹牛悴灵,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播骂蓖,決...
    沈念sama閱讀 40,835評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼积瞒,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了登下?” 一聲冷哼從身側(cè)響起茫孔,我...
    開封第一講書人閱讀 39,740評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤被芳,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后畔濒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體剩晴,經(jīng)...
    沈念sama閱讀 46,286評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡赞弥,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評(píng)論 3 340
  • 正文 我和宋清朗相戀三年趣兄,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了绽左。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片艇潭。...
    茶點(diǎn)故事閱讀 40,505評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蹋凝,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情仙粱,我是刑警寧澤房交,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布伐割,位于F島的核電站,受9級(jí)特大地震影響隔心,放射性物質(zhì)發(fā)生泄漏白群。R本人自食惡果不足惜硬霍,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,873評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧躬柬,春花似錦、人聲如沸抽减。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至史汗,卻和暖如春琼掠,著一層夾襖步出監(jiān)牢的瞬間停撞,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工怜森, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留谤牡,地道東北人副硅。 一個(gè)月前我還...
    沈念sama閱讀 48,921評(píng)論 3 376
  • 正文 我出身青樓翅萤,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親套么。 傳聞我的和親對(duì)象是個(gè)殘疾皇子培己,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評(píng)論 2 359