Longest Increasing Path in a Matrix 二维矩阵中最长的递增路径

本文介绍了一道编程题目,要求在给定的二维矩阵中找到最长的递增路径。提供了两种解法,分别是递归与动态规划(DP)结合的方法和使用广度优先搜索(BFS)。在递归解法中,利用DP数组避免重复计算,通过DFS搜索相邻位置更新最长路径。BFS解法借助queue进行层序遍历,检查相邻点的合法性并更新DP数组及结果。
摘要由CSDN通过智能技术生成

题目名称

给出二维矩阵中最长的递增路径

输入描述:

例如二维数组如下:
[
[9,9,4],
[6,6,8],
[2,1,1]
]

输出描述:

最长的递增路径为4,是[1,2,6,9]

输入样例:

3
3
9 9 4
6 6 8
2 1 1

输出样例:

4

思路

这道题给我们一个二维数组,让我们求矩阵中最长的递增路径,规定我们只能上下左右行走,不能走斜线或者是超过了边界。那么这道题的解法要用递归和DP来解,用DP的原因是为了提高效率,避免重复运算。我们需要维护一个二维动态数组dp,其中dp[i][j]表示数组中以(i,j)为起点的最长递增路径的长度,初始将dp数组都赋为0,当我们用递归调用时,遇到某个位置(x, y), 如果dp[x][y]不为0的话,我们直接返回dp[x][y]即可,不需要重复计算。我们需要以数组中每个位置都为起点调用递归来做,比较找出最大值。在以一个位置为起点用DFS搜索时,对其四个相邻位置进行判断,如果相邻位置的值大于上一个位置,则对相邻位置继续调用递归,并更新一个最大值,搜素完成后返回即可,参见代码如下:

解法一:

class Solution {
public:
    vec
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值