LeetCode 329. 矩阵中的最长递增路径(记忆化递归)

文章目录

    • 1. 题目
    • 2. 解题
      • 2.1 记忆化递归
      • 2.2 拓扑排序

1. 题目

给定一个整数矩阵,找出最长递增路径的长度。

对于每个单元格,你可以往上,下,左,右四个方向移动。
你不能在对角线方向上移动或移动到边界外(即不允许环绕)。

示例 1:
输入: nums = 
[[9,9,4],[6,6,8],[2,1,1]
] 
输出: 4 
解释: 最长递增路径为 [1, 2, 6, 9]。示例 2:
输入: nums = 
[[3,4,5],[3,2,6],[2,2,1]
] 
输出: 4 
解释: 最长递增路径是 [3, 4, 5, 6]。
注意不允许在对角线方向上移动。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-increasing-path-in-a-matrix
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

2.1 记忆化递归

class Solution {int m, n;int longest = 1;vector<vector<int>> dir = {{-1,0},{1,0},{0,1},{0,-1}};
public:int longestIncreasingPath(vector<vector<int>>& mat) {if(mat.empty() || mat[0].empty())return 0;m = mat.size(), n = mat[0].size();vector<vector<int>> s(m, vector<int>(n,0));for(int i = 0, j; i < m; ++i)for(j = 0; j < n; ++j){if(s[i][j] != 0)//走过的路不走continue;longest = max(longest, dfs(i,j,mat,s));}return longest;}int dfs(int i, int j, vector<vector<int>>& mat, vector<vector<int>>& s){if(s[i][j] != 0)return s[i][j];int x, y, k, longestpathofnext = 0;for(k = 0; k < 4; ++k){x = i + dir[k][0];y = j + dir[k][1];if(x>=0 && x<m && y>=0 && y<n && mat[i][j] > mat[x][y]){longestpathofnext = max(longestpathofnext, dfs(x,y,mat,s));}}return s[i][j] = 1+longestpathofnext;}
};

76 ms 14.1 MB

2.2 拓扑排序

见官方解答

  • 找到周围点比我小的,入度+1,统计一遍
  • 入度为0的全部入队列,BFS的最大层数为最长路径长度

我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

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

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

相关文章

DEV里的XtraGrid的GridView的一个单元格里显示大量的文字怎么办?

以下的说明是VisualStudio2010&#xff0c;Developer Express v2011 vol 1环境&#xff0c; ①设定XtraGrid的GridView-->Main-->Colums-->具体的某一列-->ColumnEdit-->设定为RichTextEdit -->设定Name属性和Encoding属性(为Uinicode(UTF-8),防止出现乱码) …

C# 页面关联类似模式窗口

在做一项功能时&#xff0c;页面需要选择“社区”&#xff0c; 首先需要选择区域&#xff0c;选完区域后&#xff0c;再选择社区&#xff0c;页面会刷新&#xff0c;而且这个社区选择Div区域一开始不可见的&#xff0c;如果在一个页面操作不便&#xff0c;所以需要开启另外一个…

java管理员模块设计_通俗易懂权限管理模块设计 - Java

最近一直在做CMS系统&#xff0c;发现一些内容其实都是重复出现的&#xff0c;例如权限管理模块。权限管理模块就是为了管理用户是否有权利访问某个权限&#xff0c;如果不能则拒绝访问。其实Java中已经有很成熟的权限管理框架&#xff0c;例如Shiro&#xff0c;spring Securit…

LeetCode MySQL 1527. Patients With a Condition(like)

文章目录1. 题目2. 解题1. 题目 Table: Patients ----------------------- | Column Name | Type | ----------------------- | patient_id | int | | patient_name | varchar | | conditions | varchar | ----------------------- patient_id is the primary ke…

Web开发中需要注意的地方

在StackExchange上有人问了这样一个问题&#xff1a;What should every programmer know about web development?&#xff08;关于Web开发&#xff0c;什么是所有程序员需要知道的&#xff1f;&#xff09;里面给出的答案非常不错&#xff0c;所以&#xff0c;我翻译转载过来。…

java怎么把数据返回给客户端_将数据从Servlet返回到Java客户端

您遇到了序列化问题.序列化是将某些数据转换为可以传输的格式的地方.有几种方法可以做到这一点,其他答案中提到了一些方法.我建议使用JSON作为您的格式.你可以从json.org获得一个很好的Java JSON库.然后你可以简单地用库创建一个JSON数组并将其写入servlet的OutputStream.publi…

LeetCode MySQL 550. 游戏玩法分析 IV

文章目录1. 题目2. 解题1. 题目 Table: Activity ----------------------- | Column Name | Type | ----------------------- | player_id | int | | device_id | int | | event_date | date | | games_played | int | ----------------------- &…

java的构造函数格式_来自模板化对象的Java 8函数构造函数

我正在使用Eclipse Luna Service Release 2(4.4.2),Java 8 u51.我正在尝试创建一个方法,该方法将基于另一个方法参数创建传递对象的实例.原型简化为public T test(Object param,T instance) {Constructor> constructor instance.getClass().getConstructors()[0]; // I act…

django 403 错误:CSRF token missing or incorrect

最近觉得SAE不错,就开始试试看,从Django开始.把原来MVC3的一个小项目转过来,记录下碰到的问题. 用的Django版本为1.4. 我比较喜欢用jquery的ajax来做表单提交(我觉得ajax比form方便...每个人喜好不同吧~) ajax提交一下,结果出事了....403错误,CSRF,还好在MVC里面也有这货,对这名…

LeetCode MySQL 574. 当选者

文章目录1. 题目2. 解题1. 题目 表: Candidate -------------- | id | Name | -------------- | 1 | A | | 2 | B | | 3 | C | | 4 | D | | 5 | E | -------------- 表: Vote ------------------- | id | CandidateId | ---…

java 捆绑_java – 如何在jar文件中捆绑图像

在这里似乎有两个问题&#xff1a;>如何让NetBeans在构建项目时将jar包含在生成的jar中&#xff1f;>如何从jar中访问映像文件&#xff1f;此应用程序适用于NetBeans 6.8并解决了两个方面的问题.假设您有一个基于ant的Java应用程序项目.这是项目的“文件”视图JP images …

Win8下右键“发送到”没有蓝牙选项的解决办法

1.打开C:\Windows\System32&#xff0c;搜索fsquirt.exe&#xff0c;这时会得到多个搜索结果&#xff0c;选择路径是C:\Windows\System32的那个&#xff0c;其他的也可以&#xff0c;只不过是英文罢了。 2.在fsquirt.exe上右键-》创建快捷方式&#xff0c;因为无法在当前位置创…

LeetCode MySQL 534. 游戏玩法分析 III

文章目录1. 题目2. 解题1. 题目 Table: Activity ----------------------- | Column Name | Type | ----------------------- | player_id | int | | device_id | int | | event_date | date | | games_played | int | ----------------------- &…

java 批量入库oracle_java操作Oracle数据库——ARRAY、TABLE类型批量入库

首先是我的数据库表(PLSQL操作)create table TEST_TABLE(yid NUMBER,ytel VARCHAR2(50),yanumber VARCHAR2(50));这里记录两种方式&#xff1a;不管哪种方式、一定要记得导入orai18n.jar否则一遇到字符串就乱码、添加不到数据第一种&#xff1a;在数据库中建立相应的j…

bzoj 1036 树的统计Count

题意&#xff1a;... 解法&#xff1a;树链剖分&#xff0c;对点进行重编号&#xff0c;这样的话线段树中点的信息就是树中点的信息。。。别的很常规。。。 1 #include<cstdio>2 #include<cstring>3 #include<algorithm>4 #define N 300105 #define lson l,m…

LeetCode 1500. Design a File Sharing System(哈希map+优先队列)

文章目录1. 题目2. 解题1. 题目 We will use a file-sharing system to share a very large file which consists of m small chunks with IDs from 1 to m. When users join the system, the system should assign a unique ID to them. The unique ID should be used once …

mupdf java_mupdf库学习

http://macleo.iteye.com/blog/1544948Java代码freetye-config --cflags2.C语言的用处其实还是很大的....C也一样&#xff0c;不经意处C语言还在发挥着巨大的作用3.踏破铁鞋无觅处啊http://zhiweiofli.iteye.com/blog/9050694.Bitmap旋转http://blog.sina.com.cn/s/blog_625def…

Centos或者Redhet开通telnet

我参考了两篇文章&#xff1a; 1、51cto的这篇最全&#xff1a; http://blog.chinaunix.net/uid-21134884-id-3015272.html 2、本园子里面的&#xff1a; http://www.cnblogs.com/xlmeng1988/archive/2012/04/24/telnet-server.html转载于:https://www.cnblogs.com/diyunpeng/a…

LeetCode 425. 单词方块(Trie树+DFS)

文章目录1. 题目2. 解题1. 题目 给定一个单词集合 &#xff08;没有重复&#xff09;&#xff0c;找出其中所有的 单词方块 。 一个单词序列形成了一个有效的单词方块的意思是指从第 k 行和第 k 列 (0 ≤ k < max(行数, 列数)) 来看都是相同的字符串。 例如&#xff0c;单…

python numpy pandas 书 全_用Python做数据分析,Numpy,Pandas,matp

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼用Python做数据分析&#xff0c;Numpy&#xff0c;Pandas&#xff0c;matplotlib是怎么也绕不开的三个包&#xff0c;我最开始学习pandas是看的《利用Python进行数据分析》&#xff0c;看了好几遍&#xff0c;不是从头到尾看了好几…