当前位置: 首页 > news >正文

LeetCode题练习与总结:三角形最小路径和--120

一、题目描述

给定一个三角形 triangle ,找出自顶向下的最小路径和。

每一步只能移动到下一行中相邻的结点上。相邻的结点 在这里指的是 下标 与 上一层结点下标 相同或者等于 上一层结点下标 + 1 的两个结点。也就是说,如果正位于当前行的下标 i ,那么下一步可以移动到下一行的下标 i 或 i + 1 。

示例 1:

输入:triangle = [[2],[3,4],[6,5,7],[4,1,8,3]]
输出:11
解释:如下面简图所示:23 46 5 7
4 1 8 3
自顶向下的最小路径和为 11(即,2 + 3 + 5 + 1 = 11)。

示例 2:

输入:triangle = [[-10]]
输出:-10

提示:

  • 1 <= triangle.length <= 200
  • triangle[0].length == 1
  • triangle[i].length == triangle[i - 1].length + 1
  • -10^4 <= triangle[i][j] <= 10^4

二、解题思路

这个问题可以通过动态规划来解决。我们可以从三角形的底部开始,逐层向上计算每个节点到底部的最小路径和。对于每个节点,其最小路径和等于其值加上其下一层相邻节点的最小路径和。这样,当我们计算到三角形的顶部时,顶部的值就是整个三角形的最小路径和。

具体步骤如下:

  1. 初始化一个与三角形相同大小的二维数组dp,用于存储每个节点到底部的最小路径和。
  2. 从三角形的最后一行开始,将这一行的值复制到dp的对应行。
  3. 从倒数第二行开始,逐行向上计算,对于每一行的每个节点,其最小路径和为该节点的值加上其下一行相邻节点的最小路径和中的较小值。
  4. 当计算到三角形的顶部时,dp[0][0]就是整个三角形的最小路径和。
  5. 返回dp[0][0]作为结果。

三、具体代码

class Solution {public int minimumTotal(List<List<Integer>> triangle) {int n = triangle.size();int[][] dp = new int[n][n];// 初始化dp数组的最后一行for (int i = 0; i < n; i++) {dp[n - 1][i] = triangle.get(n - 1).get(i);}// 从倒数第二行开始向上计算for (int i = n - 2; i >= 0; i--) {for (int j = 0; j <= i; j++) {dp[i][j] = triangle.get(i).get(j) + Math.min(dp[i + 1][j], dp[i + 1][j + 1]);}}// 返回顶部节点的最小路径和return dp[0][0];}
}

四、时间复杂度和空间复杂度

1. 时间复杂度
  • 初始化dp数组的最后一行需要遍历n个元素,时间复杂度为O(n)。
  • 双层循环中,外层循环执行了n-1次,内层循环在最坏情况下(即倒数第二行)执行了n-1次。
  • 因此,内层循环的总执行次数是1 + 2 + 3 + … + (n-1),这是一个等差数列求和,其和为((1 + n-1) * (n-1)) / 2。
  • 综合外层循环和内层循环,总的时间复杂度是O(n^2)。
2. 空间复杂度
  • dp数组的大小为n x n,用于存储每一行的最小路径和。
  • 因此,空间复杂度主要取决于dp数组的大小,即O(n^2)。

综上所述,代码的时间复杂度是O(n^2),空间复杂度是O(n^2)。

五、总结知识点

  1. 动态规划:这是一种通过将问题分解为更小的子问题来解决复杂问题的方法,通常用于优化问题,如最短路径、最大子数组和等。

  2. 二维数组dp是一个二维数组,用于存储每一行的最小路径和。在Java中,它被初始化为int[n][n],其中n是三角形的行数。

  3. 列表(List)的使用List<List<Integer>> triangle 是一个包含整数列表的列表,用于存储杨辉三角的数据。在这里,它被用来存储输入的三角形。

  4. 循环结构for 循环用于重复执行一系列操作。这里有双层循环,外层循环用于控制行数,内层循环用于计算每一行的最小路径和。

  5. 数学函数Math.min() 函数用于返回两个整数中的较小值。

  6. 数组的索引操作:在更新每一行元素时,代码通过索引来访问和修改二维数组中的元素。

  7. 列表的元素访问triangle.get(i).get(j) 用于获取列表中索引为 i 的子列表中索引为 j 的元素值。

以上就是解决这个问题的详细步骤,希望能够为各位提供启发和帮助。

相关文章:

  • 有待挖掘的金矿:大模型的幻觉之境
  • LeetCode ---400周赛
  • 在npm发布自己的组件包
  • 编程规范-代码检测-格式化-规范化提交
  • 安徽京准NTP时钟系统:GPS北斗卫星授时下的生活重塑
  • 2559. 统计范围内的元音字符串数(前缀和) o(n)时间复杂度
  • k-means聚类模型的优缺点
  • 后端 excel的导入
  • 探索k8s集群的配置资源(secret和configmap)
  • 自然语言处理(NLP)—— 主题建模
  • WMS仓储管理系统高效驱动制造企业物料管理
  • dart 基本语法
  • 【Python】认识 Python
  • 【设计模式之外观模式 -- C++】
  • 【数据结构】栈和队列-->理解和实现(赋源码)
  • Babel配置的不完全指南
  • Java Agent 学习笔记
  • JavaScript新鲜事·第5期
  • Objective-C 中关联引用的概念
  • vue和cordova项目整合打包,并实现vue调用android的相机的demo
  • Webpack 4 学习01(基础配置)
  • 阿里云爬虫风险管理产品商业化,为云端流量保驾护航
  • 当SetTimeout遇到了字符串
  • 分享一个自己写的基于canvas的原生js图片爆炸插件
  • 浅谈Kotlin实战篇之自定义View图片圆角简单应用(一)
  • 如何使用 JavaScript 解析 URL
  • 使用 QuickBI 搭建酷炫可视化分析
  • 使用Envoy 作Sidecar Proxy的微服务模式-4.Prometheus的指标收集
  • 异常机制详解
  • 原生 js 实现移动端 Touch 滑动反弹
  • 正则表达式
  • 阿里云IoT边缘计算助力企业零改造实现远程运维 ...
  • 从如何停掉 Promise 链说起
  • ‌U盘闪一下就没了?‌如何有效恢复数据
  • #如何使用 Qt 5.6 在 Android 上启用 NFC
  • $NOIp2018$劝退记
  • ()、[]、{}、(())、[[]]命令替换
  • (C++哈希表01)
  • (MTK)java文件添加简单接口并配置相应的SELinux avc 权限笔记2
  • (附源码)springboot课程在线考试系统 毕业设计 655127
  • (六)软件测试分工
  • (收藏)Git和Repo扫盲——如何取得Android源代码
  • (一)80c52学习之旅-起始篇
  • (一)为什么要选择C++
  • .NET COER+CONSUL微服务项目在CENTOS环境下的部署实践
  • .net core Redis 使用有序集合实现延迟队列
  • .NET Core Web APi类库如何内嵌运行?
  • .Net Core 中间件验签
  • .NET教程 - 字符串 编码 正则表达式(String Encoding Regular Express)
  • .net中生成excel后调整宽度
  • @SuppressWarnings(unchecked)代码的作用
  • @vueup/vue-quill使用quill-better-table报moduleClass is not a constructor
  • [ Linux 长征路第二篇] 基本指令head,tail,date,cal,find,grep,zip,tar,bc,unname
  • [ 渗透测试面试篇 ] 渗透测试面试题大集合(详解)(十)RCE (远程代码/命令执行漏洞)相关面试题
  • [20171106]配置客户端连接注意.txt