热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

LeetCode120.三角形最小路径和(动态规划、递归、记忆搜索)

三角形最小路径和题目:给定一个三角形,找出自顶向下的最小路径和。每一步只能移动到下一行中相邻的结点上。相邻的结点在这里指的是下标与上一层结点下标相
  1. 三角形最小路径和

题目:

给定一个三角形,找出自顶向下的最小路径和。每一步只能移动到下一行中相邻的结点上。

相邻的结点 在这里指的是 下标 与 上一层结点下标 相同或者等于 上一层结点下标 + 1 的两个结点。

例如,给定三角形:

[[2],[3,4],[6,5,7],[4,1,8,3]
]

自顶向下的最小路径和为 11(即,2 + 3 + 5 + 1 = 11)。

思路:

  1. 暴力法,递归,n层,left or right:2^n
  2. DP
    a.重复性(分治) problem(i,j) = min(sub(i+1,j),sub(i+1,j+1)) + a[i,j]
    b.定义状态数组 f[i,j]
    c.DP方程:f[i,j] = min(f[i+1,j],f[i+1,j+1]) + a[i,j]

方法一:动态规划

public int minimumTotal(List<List<Integer>> triangle) {int[] A &#61; new int[triangle.size() &#43; 1];for (int i &#61; triangle.size() - 1;i >&#61; 0; i&#43;&#43;) {for(int j&#61; 0;j<triangle.get(i).size();j&#43;&#43;){//左右的最小者&#xff0c;加上自身A[j] &#61; Math.min(A[j],A[j&#43;1]) &#43; triangle.get(i).get(j);}}return A[0];}

方法二&#xff1a;递归 自顶向下

int row;public int minimumTotal_1(List<List<Integer>> triangle) {row &#61; triangle.size();return helper(0,0,triangle);}private int helper(int level, int c, List<List<Integer>> triangle) {System.out.println("helper : level&#61;" &#43; level &#43; "c &#61; " &#43; c);//递归终止条件if (level &#61;&#61; row - 1){return triangle.get(level).get(c);}int left &#61; helper(level &#43; 1, c, triangle);int right &#61; helper(level &#43; 1, c &#43; 1 , triangle);return Math.min(left,right) &#43; triangle.get(level).get(c);}

方法三&#xff1a;自顶向下&#xff0c;记忆化搜索

int row;Integer[][] memo;public int minimumTotal_2(List<List<Integer>> triangle) {row &#61; triangle.size();memo &#61; new Integer[row][row];return helper(0,0,triangle);}private int helper(int level, int c, List<List<Integer>> triangle) {if (memo[level][c] !&#61; null){return memo[level][c];}if (level &#61;&#61; row - 1){return memo[level][c] &#61; triangle.get(level).get(c);}int left &#61; helper(level&#43;1,c,triangle);int right &#61; helper(level&#43;1,c&#43;1,triangle);return memo[level][c] &#61; Math.min(left,right) &#43; triangle.get(level).get(c);}

方法四&#xff1a;自底向上 DP

public int minimumTotal_3(List<List<Integer>> triangle) {int row &#61; triangle.size();int[] minlen &#61; new int[row &#43; 1];for (int level &#61; row - 1; level>&#61; 0; level&#43;&#43;) {for (int i &#61; 0; i <&#61; level; i&#43;&#43;) {minlen[i] &#61; Math.min(minlen[i],minlen[i&#43;1]) &#43; triangle.get(level).get(i);}}return minlen[0];}


推荐阅读
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • Android JSON基础,音视频开发进阶指南目录
    Array里面的对象数据是有序的,json字符串最外层是方括号的,方括号:[]解析jsonArray代码try{json字符串最外层是 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
author-avatar
文竹a
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有