【力扣hot100】64. 最小路径和

一、题目

复制代码
给定一个包含非负整数的 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 == grid[i].length
1 <= m, n <= 200
0 <= grid[i][j] <= 200

二、思路

动态规划还是不会做,需要多写多练。思考很久无果,看了眼题解才有了思路。

在这题中,右下角的最短路径和实则就是上路径和up和左路径和left取小(只能向下或右走)。而up和left也能被切分成两个矩形,所以问题逐渐变为了在每个格子取最短路径和。

显然,左上角的三个数的最短路径都是唯一的,即1,1,3,所以以此递归就能得到每个格子的最短路径和,最后取小就可以得到右下角的最短路径和了

三、题解

cpp 复制代码
class Solution {
private:
	vector<vector<int>>mem;
public:
    int dfs(vector<vector<int>>&grid,int x,int y){
		if(x>=grid[0].size()||y>=grid.size()||x<0||y<0){
			return INT_MAX;    //超出区间直接返回最大值,使其排除(即取另一条路径)
		}
		if(x==0&&y==0) return mem[0][0]=grid[0][0];
		if(mem[y][x]!=-1) return mem[y][x];    //已经计算过的直接取值
		else {
			int up=dfs(grid,x,y-1);
			int left=dfs(grid,x-1,y);
			return mem[y][x]=min(up,left)+grid[y][x];    //左上路径取小
		}
	}

    int minPathSum(vector<vector<int>>& grid) {
        mem=vector<vector<int>>(grid.size(),vector<int>(grid[0].size(),-1));
		return dfs(grid,grid[0].size()-1,grid.size()-1);
    }
};
相关推荐
沫璃染墨1 分钟前
C++ string 从入门到精通:构造、迭代器、容量接口全解析
c语言·开发语言·c++
黎阳之光18 分钟前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_1125 分钟前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia26 分钟前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
wfbcg1 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展
_日拱一卒1 小时前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode
计算机安禾1 小时前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio
unicrom_深圳市由你创科技1 小时前
做虚拟示波器这种实时波形显示的上位机,用什么语言?
c++·python·c#
SatVision炼金士1 小时前
合成孔径雷达干涉测量(InSAR)沉降监测算法体系
算法
wuweijianlove1 小时前
算法稳定性与数值误差传播研究的技术2
算法