LeetCode热题100 最小路径和

题目描述

给定一个包含非负整数的 m x n 网格 grid ,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。

说明:每次只能向下或者向右移动一步。

示例 1:

输入 :grid = \[1,3,1,1,5,1,4,2,1]
输出 :7
解释:因为路径 1→3→1→1→1 的总和最小。

示例 2:

输入 :grid = \[1,2,3,4,5,6]
输出:12

提示:

m == grid.length

n == gridi.length

1 <= m, n <= 200

0 <= gridij <= 200

思路

动态规划板子,dpij表示到达当前(i, j)的最小值,dpij = min(dpi - 1j, dpij - 1) + gridij

代码

cpp 复制代码
class Solution {
public:
    int minPathSum(vector<vector<int>>& grid) {
        int n = grid.size();
        int m  = grid[0].size();
        vector<vector<int>>dp(n, vector<int>(m, 0));

        for(int i = 0; i < n; ++i)
        {
            for(int j = 0; j < m; ++j)
            {
                if(!i && !j) dp[i][j] = grid[i][j];
                else dp[i][j] = min(i > 0 ? dp[i - 1][j] : INT_MAX, j > 0 ? dp[i][j - 1] : INT_MAX) + grid[i][j];
                
            }
        }

        return dp[n - 1][m - 1];
    }
};
相关推荐
Shadow(⊙o⊙)8 小时前
QT常用控件3.0,font字体设置,toolTip提示,focusPolicy焦点定位原则,中型控件StyleSheet样式表。
服务器·开发语言·前端·c++·qt
Shadow(⊙o⊙)8 小时前
QT常用控件2.0,windowOpacity窗口透明度,Cursor光标设置
开发语言·c++·qt
Lazionr8 小时前
类和对象(上):走进面向对象编程
c++
神仙别闹8 小时前
基于C语言处理机调度算法的实现
服务器·c语言·算法
Brilliantwxx8 小时前
【算法从零到千】【16-23】 二分算法
数据结构·算法
晚风叙码8 小时前
《C++面向对象进阶:static成员、友元、匿名对象与拷贝优化详解》
c++
j7~8 小时前
【C++】STL--string类--拆析解剖string以及string类的底层详解(1)
开发语言·c++·ascii编码·string类·auto和范围for
草莓熊Lotso8 小时前
【Linux网络】深入理解 TCP 协议(二):序号机制、流量控制与连接管理
linux·运维·服务器·网络·c++·tcp/ip
8Qi814 小时前
回文子串(Palindromic Substrings)—— 题解
算法·leetcode·职场和发展·动态规划