「动态规划」如何求下降路径最小和?

931. 下降路径最小和icon-default.png?t=N7T8https://leetcode.cn/problems/minimum-falling-path-sum/description/

给你一个n x n的方形整数数组matrix,请你找出并返回通过matrix的下降路径的最小和。下降路径可以从第一行中的任何元素开始,并从每一行中选择一个元素。在下一行选择的元素和当前行所选元素最多相隔一列(即位于正下方或者沿对角线向左或者向右的第一个元素)。具体来说,位置(row, col)的下一个元素应当是(row + 1, col - 1)、(row + 1, col)或者(row + 1, col + 1)。

  1. 输入:matrix = [[2,1,3],[6,5,4],[7,8,9]],输出:13,解释:如图所示,为和最小的两条下降路径。
  2. 输入:matrix = [[-19,57],[-40,-5]],输出:-59,解释:如图所示,为和最小的下降路径。

提示:n == matrix.length == matrix[i].length;1 <= n <= 100;-100 <= matrix[i][j] <= 100。


我们用动态规划的思想来解决这个问题。

确定状态表示:根据经验和题目要求,我们用dp[i][j]表示:到达[i, j]位置时,所有下降路径的最小和

推导状态转移方程:想要到达[i, j]位置,只有3种情况:

  • 先到达[i - 1, j - 1]位置,再下降到[i, j]位置。此时,到达[i, j]位置的最小和,应该为到达[i - 1, j - 1]位置的最小和加上矩阵中[i, j]位置的元素,也就是dp[i - 1][j - 1] + matrix[i][j]。
  • 先到达[i - 1, j]位置,再下降到[i, j]位置。此时,到达[i, j]位置的最小和,应该为到达[i - 1, j]位置的最小和加上矩阵中[i, j]位置的元素,也就是dp[i - 1][j] + matrix[i][j]。
  • 先到达[i - 1, j + 1]位置,再下降到[i, j]位置。此时,到达[i, j]位置的最小和,应该为到达[i - 1, j + 1]位置的最小和加上矩阵中[i, j]位置的元素,也就是dp[i - 1][j + 1] + matrix[i][j]。

而到达[i, j]位置的最小和,应该是上面三种情况的最小值,即dp[i][j] = min(dp[i - 1][j - 1] + matrix[i][j], dp[i - 1][j] + matrix[i][j], dp[i - 1][j + 1] + matrix[i][j]) = min(dp[i - 1][j - 1], dp[i - 1][j], dp[i - 1][j + 1]) + matrix[i][j]

初始化:根据状态转移方程,我们发现,在填写dp表的最上面一行、最左边一列和最右边一列时,会有越界访问。理论上,我们要对其进行初始化。这里我们采用增加辅助结点的方式来初始化。我们在dp表的最上面、最左边和最右边分别加上一行两列。接下来,我们要考虑,如何初始化辅助结点,才能让后续的填表是正确的。

观察状态转移方程,我们发现有一项是min(dp[i - 1][j - 1], dp[i - 1][j], dp[i - 1][j + 1]),用文字来表述,就是dp表中,该位置上面3个位置的最小值。再来分析一下,如果没有辅助结点,dp表第一行的值就应该是矩阵对应位置的值。现在有了辅助结点,只需要使min(dp[i - 1][j - 1], dp[i - 1][j], dp[i - 1][j + 1])这一项是0,就能符合预期。所以,最上面一行辅助结点就应该填充0。我们把目前已知的dp表画出来:

0 0 0 0 0
* ? ? ? *
* ?   ? *
* ?   ? *

此时只需要考虑*位置的辅助结点应该如何填写。现在最上面一行?位置的值已经是正确的了,只需要保证最左边和最右边两列的?位置的值也是正确的。再来观察状态转移方程,我们发现,影响结果的一项依然是min(dp[i - 1][j - 1], dp[i - 1][j], dp[i - 1][j + 1]),其中dp[i - 1][j - 1]和dp[i - 1][j + 1]会涉及到辅助结点。所以,为了使得求最小值时,辅助结点的值不会影响结果,应该将其初始化为+∞。dp表中*位置的辅助结点,也就是最左边和最右边两列,除了最上面一行的0以外,都要初始化为+∞。由于辅助结点的值并没有容易造成溢出风险的运算,所以将其设为INT_MAX就行了。

综上所述:我们在最上面、最左边和最右边分别增加一行两列辅助结点,并把最上面一行辅助结点初始化为0,把最左边和最右边两列辅助结点中,除了最上面一行之外,都初始化为INT_MAX

填表顺序:观察状态转移方程,dp表每个位置的值都依赖于上面3个位置的值,所以应从上往下填表,至于左右顺序无所谓,这里选择从左往右填表。

返回值:由于要返回的是所有下降路径的最小和,我们并不知道最终会下降到最下面一行的哪个位置,再根据状态表示,我们应该返回的是dp表最下面一行中,除了最左边和最右边的2个元素之外,其他元素的最小值(事实上,把最左边和最右边的2个元素考虑进去也没什么问题,毕竟INT_MAX不会影响求最小值的结果)。

细节问题:由于新增了一行两列辅助结点,所有dp表的规模会比矩阵多一行两列。题目描述中,矩阵是方形的,假设其规模是n x n,那么dp表的规模就是(n + 1) x (n + 2)。另外,由于新增了辅助结点,需要时刻注意下标的映射关系:dp表的[i, j]位置对应矩阵的[i - 1, j - 1]位置

时间复杂度:O(N^2),空间复杂度:O(N^2)。

class Solution {
public:
    int minFallingPathSum(vector<vector<int>>& matrix) {
        size_t n = matrix.size();

        // 创建dp表
        vector<vector<int>> dp(n + 1, vector<int>(n + 2, INT_MAX));

        // 初始化
        fill(dp[0].begin(), dp[0].end(), 0);

        // 填表
        for (int i = 1; i <= n; i++) {
            for (int j = 1; j <= n; j++) {
                dp[i][j] =
                    min(dp[i - 1][j - 1], min(dp[i - 1][j], dp[i - 1][j + 1])) +
                    matrix[i - 1][j - 1];
            }
        }

        // 返回结果
        return *min_element(dp[n].begin() + 1, dp[n].end() - 1);
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/683973.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

CentOS 环境下 PostgreSQL 在线安装和源码安装详解

1、内容概述 昨天给大家简单的介绍了一下 PostgreSQL,并且在Windows系统上通过图形化界面的方式搭建好了环境&#xff0c;今天我们就来学习一下如何在Linux 系统上搭建 PostgreSQL环境&#xff0c;我会给大家介绍在线安装、离线源码安装以及Docker 安装三种方式。 2、在线安装…

umijs 服务端渲染(SSR) 指南

umijs 服务端渲染&#xff08;SSR&#xff09; 指南 Umi 是什么&#xff1f; Umi&#xff0c;中文可发音为乌米&#xff0c;是可扩展的企业级前端应用框架。Umi 以路由为基础的&#xff0c;同时支持配置式路由和约定式路由&#xff0c;保证路由的功能完备&#xff0c;并以此进…

枚举(enum)+联合体(union)

枚举联合 一.枚举类型1.枚举类型的声明2.枚举类型的优点3.枚举类型的使用 二.联合体1.联合体类型的声明2.联合体的特点3.相同成员的结构体和联合体对比4.联合体大小的计算5.联合体的练习&#xff08;判断大小端&#xff09;6.联合体节省空间例题 一.枚举类型 1.枚举类型的声明…

安全U盘和普通U盘有什么区别?

安全U盘&#xff08;也称为加密U盘或安全闪存驱动器&#xff09;与普通U盘肯定是有一些区别的&#xff0c;从字面意思上来看&#xff0c;就能看出&#xff0c;安全U盘是能够保护文件数据安全性的&#xff0c;普通U盘没这一些功能的&#xff0c;可随意拷贝文件&#xff0c;不防盗…

Hadoop3:MapReduce源码解读之Mapper阶段的TextInputFormat切片机制(3)

Job那块的断点代码截图省略&#xff0c;直接进入切片逻辑 参考&#xff1a;Hadoop3&#xff1a;MapReduce源码解读之Mapper阶段的Job任务提交流程&#xff08;1&#xff09; 5、TextInputFormat源码解析 类的继承关系 它的内容比较少 重写了两个父类的方法 这里关心一下泛型…

《开源模型食用指南》基于Linux环境快速部署开源模型,更适合中国宝宝的部署教程

今天给大家推荐一个非常适合中国宝宝学习的专属大模型教程&#xff0c;也就是它《开源模型食用指南》&#xff01; 当前百模大战正值火热&#xff0c;开源LLM层出不穷。 如今国内外已经涌现了众多优秀开源LLM&#xff0c;国外如LLaMA、Alpaca&#xff0c;国内如ChatGLM、BaiCh…

【Unity Shader入门精要 第13章】使用深度和法线纹理(一)

1. 原理 深度纹理的本质是一张RenderTexture&#xff0c;只不过其中记录的不是颜色值&#xff0c;而是一个深度值 这些深度值来自于顶点在空间变换后得到的归一化设备坐标&#xff08;NDC&#xff09;的Z值 由于NDC坐标的分量取值范围在[-1, 1]之间&#xff0c;要使颜色值能…

欧盟EDPS发布首份生成式人工智能与数据安全指南解读

6月3日&#xff0c;欧洲数据保护监督机构&#xff08;EDPS&#xff09;在其官网上发布了题为《生成式人工智能与EUDPR》的指南&#xff08;注&#xff1a;EUDPR指的是《欧盟2018/1725号条例》&#xff09;&#xff0c;这是首份适用于欧盟机构的人工智能与数据安全指南。 01 指南…

STM32 SPI驱动读取LSM6DSRTR

提示&#xff1a;通过SPI驱动读取传感器数据 文章目录 前言一、LSM6DSRTR二、配置步骤1.配置SPI2.引入 LSM驱动库3.结果 总结 前言 制作一个倾角传感器&#xff0c;通过SPI读取LSM6DSRTR的加速度数据转换为角度&#xff0c;不用IIC的原因是考虑IIC通讯的协议过于繁琐&#xff…

c# iText使用

引入包 用nuget安装itext和itext.bouncy-castle-adapter包&#xff1a; 创建pdf string path "a.pdf"; PdfWriter writer new PdfWriter(path); PdfDocument pdfDoc new PdfDocument(writer); var docnew Document(pdfDoc); Paragraph p new Paragraph(&quo…

Java装饰器模式,装饰器模式通常通过创建一个接口和一个或多个实现了该接口的类来开始,然后创建装饰器类,这些类也实现了相同的接口

1、定义一个接口Component public interface Component { void operation(); }2、创建一个实现了Component接口的简单类SimpleComponent public class SimpleComponent implements Component { Override public void operation() { System.out.println("SimpleCom…

正大国际期货:什么是主力合约?

一个期货品种&#xff0c;在同一时间段&#xff0c;会上市多个月份的合约&#xff0c; 由于主力合约交易量大&#xff0c;流动性高&#xff0c;一般建议新手交易主力合约。 主力合约通常指交易集中&#xff0c;流动性好的合约 &#xff0c;即在一段时间内交易量和持仓量最大的…

java框架树结构实现(带层级、编码、排序)

1、需求 实现一个影像资料库的功能&#xff0c;用树结构对资料进行分类 2、数据结构 通过id、pid表示父子关系 通过code表示层级关系 通过layer表示层级 通过sort进行排序 3、实体类 package org.jeecg.modules.image.entity;import com.baomidou.mybatisplus.annotation…

交叉编译freetype

目录 一、前言 二、交叉编译 freetype 1.交叉编译安装工具链 zlib 2.交叉编译安装工具链 libpng 3.交叉编译安装工具链 freetype 4.编译测试发现错误并解决 5.上机测试 一、前言 交叉编译常见错误解决方法可看&#xff1a;交叉编译中常见错误解决方法_交叉编译后fail t…

DevExpress Installed

一、What’s Installed 统一安装程序将DevExpress控件和库注册到Visual Studio中&#xff0c;并安装DevExpress实用工具、演示应用程序和IDE插件。 Visual Studio工具箱中的DevExpress控件 Visual Studio中的DevExpress菜单 Demo Applications 演示应用程序 Launch the Demo…

基于细节增强卷积和内容引导注意的单图像去雾

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 摘要Abstract文献阅读&#xff1a;DEA-Net&#xff1a;基于细节增强卷积和内容引导注意的单图像去雾1、研究背景2、方法提出3、相关知识3.1、DEConv3.3、多重卷积的…

Springboot+druid+多数据源

背景&#xff1a;早期项目是springboot2.x druid 的单数据源工程&#xff0c;其中使用了dblink的方式进行跨数据库访问。现在客户的机房搬迁&#xff0c;记账的下游数据库说是搬到不同区域&#xff0c;dblink的方式需要长期占用资源&#xff0c;需要修改成直连方式。 按照AI的…

AttenFace一个基于人脸识别的实时考勤验证系统算法研究

0 、引言 论文提出了一个使用面部识别、允许实时监控考勤的考勤系统&#xff0c; 可以检查由于欺骗和遗漏造成的欺诈。 论文地址&#xff1a;https://arxiv.org/abs/2211.07582v1 1. 概述 在大学和其他机构的课堂上&#xff0c;通常会进行考勤。然而&#xff0c;这种方式往往…

工业互联网基本概念及关键技术(295页PPT)

资料介绍&#xff1a; 工业互联网的核心是通过工业互联网平台把设备、生产线、工厂、供应商、产品和客户紧密地连接融合起来。这种连接能够形成跨设备、跨系统、跨厂区、跨地区的互联互通&#xff0c;从而提高效率&#xff0c;推动整个制造服务体系智能化。同时&#xff0c;工…

2024最新华为OD机试-C/D卷 - 在线OJ使用说明

文章目录 &#x1fa90;在线 OJ 入口&#x1f3a7;申请OD使用权限&#x1f353;在线 OJ 的使用说明OJ主界面专题系列语言支持评测结果 &#x1fa90;在线 OJ 入口 &#x1f517; 2024最新华为OD机试 - 在线OJ入 &#x1f3a7;申请OD使用权限 本专栏配套 OJ 的为了配合考友更高…