Java 动态规划 Leetcode 931. 下降路径最小和

news2024/11/25 11:41:37

代码展示:

class Solution {
    public int minFallingPathSum(int[][] matrix) {
        int n=matrix.length;
        //创建dp数组
        int[][]dp=new int[n+1][n+2];
        //初始化
        for(int i=1;i<=n;i++){
            dp[i][0]=dp[i][n+1]=Integer.MAX_VALUE;
        }
        //填充数组
        for(int i=1;i<=n;i++){
            for(int j=1;j<=n;j++){
                dp[i][j]=Math.min(dp[i-1][j-1],Math.min(dp[i-1][j],dp[i-1][j+1]))+matrix[i-1][j-1];
            }
        }
        //返回值
        int min=Integer.MAX_VALUE;
        for(int j=1;j<=n;j++){
            min=Math.min(min,dp[n][j]);
        }
        return min;
    }
}

对于动态规划题目依旧是分为5步来解决

        1.状态表示

                用dp数组来表示储存每个位置的下降路径最小和,即dp【i】【j】表示到达i

,j位置的下降路径最小和

        2.状态转移方程

                我们从最近的位置进行分析,对于【i】【j】位置来说,我们可以从【i-1】【j-1】,【i-1】【j】,【i-1】【j+1】三个位置到达,而我们选择从哪个位置去【i】【j】位置呢,肯定是选择下降路径最小的,所以我们可以比较到达这3个位置的最小下降路径即dp【i-1】【j-1】,dp【i-1】【j】,dp【i-1】【j+1】,在里面选出最小的,然后在从选出的这个位置移动到【i】【j】位置,加上【i】【j】位置的路径值,便是dp【i】【j】的值

                于是我们得到了状态转移方程: dp[i][j]=Math.min(dp[i-1][j-1],Math.min(dp[i-1][j],dp[i-1][j+1]))+matrix[i-1][j-1];

        3.初始化

                为了方便初始化,我们可以通过添加辅助结点的方式来辅助初始化,我们在创建dp表时,相较于matrix数组,我们可以多添加一行,两列,辅助结点中的值要保证后续的赋值是正确的,并且还要注意下标之间的映射关系

        4.填充数组

                由于要先知道上面的3个值才能知道当前的值,所以赋值要从上而下

        5.返回值

                由于只要到达最后一行便结束一条下降路径,所以要判断最小下降路径,就要找到dp表中最后一行的最小值

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【网络安全】Burpsuite v2021.12.1安装激活配置快捷启动

Burpsuite v2021.12.1安装&激活&配置&快捷启动 一、下载激活包二、配置JDK11三、启动激活 一、下载激活包 需要下载的内容&#xff1a; Burp Suite jar包JDK11激活jar包汉化jar包 下面是已经下载好的&#xff0c;可以直接使用 BurpSuite网盘下载链接 提取码&#…

单键触摸开关/双键触摸式照明灯/触摸式延时照明灯电路设计

单键触摸开关 触摸式照明开关是一种非常实用的电子开关&#xff0c;用手触摸一下导电片&#xff0c;就能实现开关动作 &#xff0c;使用方便可靠、电路简单、性能稳定、寿命长、节电效果明显。适合于爱好者自制。 一、电路工作原理 电路原理如图 21 所示。 接通电源后&#…

RabbitMQ ---- Hello World

RabbitMQ ---- Hello World 1. 依赖2. 消息生产者3. 信息消费者 本节使用 Java 编写两个程序。发送单个消息的生产者和接收消息并打印出来的消费者。 1. 依赖 <!--指定 jdk 编译版本--><build><plugins><plugin><groupId>org.apache.maven.plu…

Scratch 随机平台跳跃

Scratch 随机平台跳跃 本程序转换为HTML后运行。程序在随机位置生成红、蓝平台各13个&#xff0c;通过W、A、S、D键控制角色移动&#xff0c;移动时把标记下落的变量设为1。该变量为1时角色下落&#xff0c;碰到边缘或平台时结束下落&#xff0c;变量设为0。这种方案的缺陷是角…

Databricks推出AI模型SDK,能自动生成SQL代码

近日一款AI模型的发布&#xff0c;或将有助于提高开发效率。据悉&#xff0c;最近Databricks发布大数据分析平台Spark所用的 AI 模型 SDK&#xff0c;开发者写代码时&#xff0c;可用英文下指令&#xff0c;编译器就会将英文指令转换为 PySpark 或 SQL 语言代码&#xff0c;以提…

偏振光的斯托克斯矢量表示法

《光纤偏振模色散原理 测量与自适应补充技术》张晓光 第二章

【Linux后端服务器开发】进程与地址空间概述

目录 一、进程创建 二、进程状态 1. 运行状态R 2. 睡眠状态S 3. 僵尸状态Z 4. 孤儿进程 三、进程优先级 PRI 四、地址空间的层次结构 五、虚拟地址和物理地址 一、进程创建 fork()函数创建子进程&#xff0c;若创建成功&#xff0c;则给父进程返回子进程的pid&#x…

Python基础教程:异常处理try...except语句

Python是一门非常灵活且易于学习的编程语言&#xff0c;在日常开发中被广泛应用。然而&#xff0c;由于各种原因&#xff0c;我们的代码可能会出现异常情况&#xff0c;例如输入错误、文件读写异常等等。Python异常处理是Python中重要的一部分&#xff0c;为了保证程序的稳定性…

用表格制作网页

利用表格制作网页 实验目标 该网页将利用设计页面的布局&#xff0c;制楚雄师院的页面简介。通过该种制作&#xff0c;我们可以体会到表格在布局设计中的实际运用&#xff0c;体会如何使用表格来控制页面中的元素对象&#xff0c;已达到自然&#xff0c;生动的配置构成元素…

Linux无法访问github解决方案【修改/etc/hosts文件,加上GitHub网站的IP地址】

ChatGPT神中神&#xff01; 省流&#xff1a;修改/etc/hosts文件&#xff0c;加上GitHub网站的IP地址。 "Failed connect to github.com:443; 拒绝连接" 错误通常表示你的系统无法建立与GitHub的安全连接。这可能是由于网络问题、防火墙设置或代理配置等原因引起的。…

unbuntu 22.04 安装和卸载企业微信

every blog every motto: You can do more than you think. https://blog.csdn.net/weixin_39190382?typeblog 0. 前言 记录有关在ubuntu22.04上安装和卸载企业微信 以及企业微信无法打开问题处理 1. 正文 1.1 安装 下载wine环境 http://archive.ubuntukylin.com/softwar…

apache hudi 初见

git clone https://gitee.com/apache/Hudi.git docker pull yml 文件里面的镜像 然后 docker-compose -f docker-compose_hadoop284_hive233_spark244.yml -p 6p6 up -d 然后就是 在这里插入代码片# Licensed to the Apache Software Foundation (ASF) under one or more …

MySQL之InnoDB存储结构 | 京东物流技术团队

1 InnoDB存储引擎 InnoDB存储引擎最早由Innobase Oy公司开发&#xff08;属第三方存储引擎&#xff09;。从MySQL 5.5版本开始作为表的默认存储引擎。该存储引擎是第一个完整支持ACID事务的MySQL存储引擎&#xff0c;特点是行锁设计、支持MVCC、支持外键、提供一致性非锁定读&…

机器学习实战 | 股票价格预测项目(深度学习初级)

目录 简介技术流程1. 载入依赖包2. 读取数据集3. 从数据集中分析价格4. 对数据排序5. 数据标准化6. 创建、训练和保存LSTM网络7. 使用LSTM模型进行股票价格预测8. 可视化预测和实际结果 完整程序 简介 准备写个系列博客介绍机器学习实战中的部分公开项目。首先从初级项目开始。…

面试题之spring源码

IOC的底层原理 &#xff1a; Spring是如何循环依赖的。&#xff08;三级缓存&#xff0c;提前曝光&#xff09;&#xff1a; 循环依赖的定义:循环依赖就是循环引用&#xff0c;也就是两个或两个以上bean对象互相持有对方&#xff0c;最终形成闭环&#xff0c;比如A依赖B,B依赖C…

文件夹加密软件怎么选?文件夹加密软件盘点

文件夹是电脑储存数据的重要工具&#xff0c;那么该如何保护文件夹的数据安全呢&#xff1f;使用合适的文件夹加密软件可能是最简单的方法。那么文件夹加密软件该怎么选呢&#xff1f; 文件夹加密超级大师 文件夹加密超级大师可以说是最全能的文件夹加密软件&#xff0c;它拥有…

自己编写chrome插件

1.首先你需要一个menifest.json文件 {"manifest_version": 3,"name": "My Extension","version": "2.0","action": {"default_popup": "popup.html","default_icon": "icon.…

winform弹出消息自动消失

winform弹出消息自动消失 弹出消息后&#xff0c;在指定时间毫秒后消失.消息中包含异常消息&#xff0c;自动一直展示&#xff0c;点击关闭显示&#xff1b; 效果如图 using System; using System.Collections.Generic; using System.Text; using System.Threading.Tasks;usi…

保姆级系列教程-玩转Fiddler抓包教程(1)-HTTP和HTTPS基础知识

1.简介 有的小伙伴或者童鞋们可能会好奇地问&#xff0c;不是讲解和分享抓包工具了怎么这里开始讲解HTTP和HTTPS协议了。这是因为你对HTTP协议越了解&#xff0c;你就能越掌握Fiddler的使用方法&#xff0c;反过来你越使用Fiddler&#xff0c;就越能帮助你了解HTTP协议。 Fid…

全网最全,项目管理工具大合集!

早上好&#xff0c;我是老原。 很久没给大家更新工具&#xff0c;本以为之前更新的也够大家用了&#xff0c;没想到还是有很多小友来私信老原好用工具。 关注我比较久的粉丝都知道&#xff0c;我提倡的工具在精不在多&#xff0c;更多的把精力放在自身上&#xff0c;还有啥不…