leetcode329. 矩阵中的最长递增路径

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

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

示例 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]。注意不允许在对角线方向上移动。

思路:记忆化搜索即可。

public class Solution {private static final int[][] dirs = {{0, 1}, {1, 0}, {0, -1}, {-1, 0}};private int m, n;public int longestIncreasingPath(int[][] matrix) {if (matrix.length == 0) return 0;m = matrix.length; n = matrix[0].length;int[][] cache = new int[m][n];int ans = 0;for (int i = 0; i < m; ++i)for (int j = 0; j < n; ++j)ans = Math.max(ans, dfs(matrix, i, j, cache));return ans;}private int dfs(int[][] matrix, int i, int j, int[][] cache) {if (cache[i][j] != 0) return cache[i][j];for (int[] d : dirs) {int x = i + d[0], y = j + d[1];if (0 <= x && x < m && 0 <= y && y < n && matrix[x][y] > matrix[i][j])cache[i][j] = Math.max(cache[i][j], dfs(matrix, x, y, cache));}return ++cache[i][j];}
}

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

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

相关文章

Query Ajax 实例 ($.ajax、$.post、$.get)

Jquery在异步提交方面封装的很好&#xff0c;直接用AJAX非常麻烦&#xff0c;Jquery大大简化了我们的操作&#xff0c;不用考虑浏览器的诧异了。 推荐一篇不错的jQuery Ajax 实例文章&#xff0c;忘记了可以去看看&#xff0c;地址为&#xff1a;http://www.cnblogs.com/yeer/a…

C++:18---const关键字(附常量指针、指针常量、常量指针常量)

一、const变量的一些基本特点 ①const修饰的变量不能被修改const int a=10; a=20;//错误②因为const修饰的变量不能被修改,所以必须被初始化int a=10; const int b=a; //正确 const int c=10; //正确③const修饰的变量可以赋值给其他值const int a=10; int b=a;//正确④可以有…

C:01---数据类型与ASCII

一、整型 int 取值范围:-32768~32767unsigned int 取值范围:0~65535short /short int 取值范围:比int小unsigned short 无符号短整型long 长整型定义时,后面加上l或L有符号与无符号数: unsigned:无符号数,一般用来表示数据signed:有符号数,一般用来表示数字整型占…

leetcode330. 按要求补齐数组 顶级难度玄学贪心

给定一个已排序的正整数数组 nums&#xff0c;和一个正整数 n 。从 [1, n] 区间内选取任意个数字补充到 nums 中&#xff0c;使得 [1, n] 区间内的任何数字都可以用 nums 中某几个数字的和来表示。请输出满足上述要求的最少需要补充的数字个数。 示例 1: 输入: nums [1,3], …

C:02---scanf、printf

一、printf 控制符 ①精度控制:输入小数点后m位(%.mf)。右对齐5位,保留小数点后m位(%d.mf)%f、%lf默认输出6位小数②宽度:%md(打印m为,右对齐,多出m位照常打印)。%-md(打印m位,左对齐,多出m位照常打印)③长度:h表示短(打印短整型short:%hd),l表示长(打印长…

C++:20---成员变量初始化方式

成员变量初始化有三种方式: 在构造函数体内赋值初始化在自定义的公有函数体中赋值初始化(一般用于成员变量的初始化)在构造函数的成员初始化列表初始化一、构造函数体内初始化 说明:在构造函数体内的初始化方式,本质是是为成员变量赋值,而不是真正意义上的初始化,这点要…

leetcode339. 嵌套列表权重和

给定一个嵌套的整数列表&#xff0c;请返回该列表按深度加权后所有整数的总和。 每个元素要么是整数&#xff0c;要么是列表。同时&#xff0c;列表中元素同样也可以是整数或者是另一个列表。 示例 1: 输入: [[1,1],2,[1,1]] 输出: 10 解释: 因为列表中有四个深度为 2 的 1…

C++:19---this指针

一、this指针介绍 概念:this指针是成员函数的一个隐式参数,在类中本质上就是对象的指针(常量指针)特点:在成员函数中可通过this指针区别成员变量与形参变量this可以显式调用示例代码:class Cperson{private:int age;float height;public:void InitPerson(int age,float hei…

leetcode346. 数据流中的移动平均值

给定一个整数数据流和一个窗口大小&#xff0c;根据该滑动窗口的大小&#xff0c;计算其所有整数的移动平均值。 示例: MovingAverage m new MovingAverage(3); m.next(1) 1 m.next(10) (1 10) / 2 m.next(3) (1 10 3) / 3 m.next(5) (10 3 5) / 3 思路&#xff1…

(二十)TCPIP面试宝典-进入大厂必备总结(中)

TCP 作为传输层的协议,是一个IT工程师素养的体现,也是面试中经常被问到的知识点。在此,我将 TCP 核心的一些问题梳理了一下,希望能帮到各位。 实际上这篇文章相当于是复习之前的网络基础部分。只不过这篇文章的提问方式更灵活,也是让读者们懂得变通,更熟悉TCP。 前两篇文…

leetcode263. 丑数

编写一个程序判断给定的数是否为丑数。 丑数就是只包含质因数 2, 3, 5 的正整数。 示例 1: 输入: 6 输出: true 解释: 6 2 3 示例 2: 输入: 8 输出: true 解释: 8 2 2 2 示例 3: 输入: 14 输出: false 解释: 14 不是丑数&#xff0c;因为它包含了另外一个质因数 7。…

(二十一)TCPIP面试宝典-进入大厂必备总结(下)

TCP 作为传输层的协议,是一个IT工程师素养的体现,也是面试中经常被问到的知识点。在此,我将 TCP 核心的一些问题梳理了一下,希望能帮到各位。 实际上这篇文章相当于是复习之前的网络基础部分。只不过这篇文章的提问方式更灵活,也是让读者们懂得变通,更熟悉TCP。 上一篇文…

C++:23 再议const的用法(下)

上一篇文章折腾了一波粉丝,那么这一篇文章稍微温柔一些。 我主要开始说如何正确使用const 1.不能将const 修饰的任何对象、引用和指针作为赋值表达式的左值。 const int cx=100; const int & rcx=cx; const int * pcx=&cx; cx=200; //error rcx=200; //error *pcx=200…

C++:22 再议const的作用(上)

我在C++:18篇里说过const的用法,这里我有必要再提升进阶下const的理解。 因为你可能只知道他是怎么用的,但是他为什么这样用,其他用法呢? 首先回顾下const有什么主要的作用? (1)可以定义const常量,具有不可变性。 (2)便于进行类型检查,使编译器对处理内容有更多了解…

leetcode57. 插入区间

给出一个无重叠的 &#xff0c;按照区间起始端点排序的区间列表。 在列表中插入一个新的区间&#xff0c;你需要确保列表中的区间仍然有序且不重叠&#xff08;如果有必要的话&#xff0c;可以合并区间&#xff09;。 示例 1: 输入: intervals [[1,3],[6,9]], newInterval …

C:03---运算符优先级

二话不说先看运算符的优先级表: 一、逗号运算符 格式:整个逗号表达式的值返回的结果是最后一个表达式的值使用起来,最好加上括号来返回最后一个表达式的值。否则逗号表达式的意义将失效(见下面演示案例)(表达式1, 表达式2, 表达式3....); #include <stdio.h> int ma…

C++: 21---引用和指针

一般说到谁和谁怎么样,要么说两者的相似点,要么两者的区别,这里我们也要说二者的区别和联系,同时,也不仅仅是区别和联系这么简单,因为你可能会发现在变量赋值,函数传参这两点还是有很多值得品一品的。 最直观的赋值方面的区别 首先我们先说二者的区别和联系。 (1)指针…

Oracle数据库Date类型查询问题(

浅谈Oracle数据库Date类型查询问题用过Oracle数据库的朋友应该知道&#xff0c;Oracle数据库在以Date类型为查询条件时存在一个小小的BUG&#xff0c;如&#xff1a;select * from tableName where createDate > to_date(2007-01-01,yyyy-mm-dd) and createDate < to_dat…

(二十二)深入浅出TCPIP之实战篇—用c++开发一个http服务器

在当前的网络编程专栏前十几篇文章里&#xff0c;我已经说明了TCPIP常用的一些原理&#xff0c;那么接下来我将逐步进入到实战编程阶段&#xff1a;本篇文章我将带大家用C做一个http服务器。既然想实现一个http服务器&#xff0c;首先必须要熟悉的就是http协议知识&#xff0c;…

C++:19---重载与模板、模板特例化

一、重载与模板 函数模板可以被另一个模板或一个普通非模板函数重载如果涉及函数模板,则函数匹配规则会有以下的约束:如果同样好的函数中只有一个是非模板函数,则选择此函数如果同样好的函数中没有非模板函数,而有多个函数模板,则其中一个模板比其他模板更特例化,则选择此…