leetcode 329. 矩阵中的最长递增路径

题目:329. 矩阵中的最长递增路径 - 力扣(LeetCode)

数据规模很小,排序就够了

cpp 复制代码
struct Node {
    int x;
    int y;
    int val;
    Node* up = nullptr;
    Node* down = nullptr;
    Node* left = nullptr;
    Node* right = nullptr;
    int length = 0;
    Node(int _x, int _y, int _v) {
        x = _x;
        y = _y;
        val = _v;
    }
};
bool myComp(Node* a, Node* b) {
    return a->val < b->val;
}
class Solution {
public:
    int longestIncreasingPath(vector<vector<int>>& matrix) {
        vector<Node*> arr;
        int upIdx, leftIdx;
        for (int i = 0; i < matrix.size(); i++) {
            vector<int>& t = matrix[i];
            for (int j = 0; j < t.size(); j++) {
                Node* node = new Node(i, j, t[j]);
                arr.push_back(node);
                if (i > 0) {
                    upIdx = (i - 1) * t.size() + j;
                    node->up = arr[upIdx];
                    arr[upIdx]->down = node;
                }
                if (j > 0) {
                    leftIdx = i * t.size() + j - 1;
                    node->left = arr[leftIdx];
                    arr[leftIdx]->right = node;
                }
            }
        }
        sort(arr.begin(), arr.end(), myComp);
        int max;
        int ret = 1;
        for (int i = 0; i < arr.size(); i++) {
            Node* node = arr[i];
            max = 0;
            if (node->left && node->left->val < node->val && node->left->length > max) {
                max = node->left->length;
            }
            if (node->right && node->right->val < node->val && node->right->length > max) {
                max = node->right->length;
            }
            if (node->up && node->up->val < node->val && node->up->length > max) {
                max = node->up->length;
            }
            if (node->down && node->down->val < node->val && node->down->length > max) {
                max = node->down->length;
            }
            node->length = max + 1;
            if (node->length > ret) {
                ret = node->length;
            }
        }
        return ret;
    }
};
相关推荐
iAkuya25 分钟前
(leetcode)力扣100 57电话号码的字母组合(回溯)
算法·leetcode·深度优先
想进个大厂4 小时前
代码随想录day31 贪心05
数据结构·算法·leetcode
橘颂TA4 小时前
【剑斩OFFER】算法的暴力美学——力扣 207 题:课程表
数据结构·c++·算法·leetcode·职场和发展
有一个好名字4 小时前
力扣-迷宫中离入口最近的出口
算法·leetcode·职场和发展
踩坑记录4 小时前
leetcode hot100 226. 翻转二叉树 easy 递归 层序遍历 BFS
算法·leetcode·宽度优先
鱼跃鹰飞5 小时前
Leetcode会员尊享面试100题:333.最大二叉搜索子树
数据结构·算法·leetcode·面试
鱼跃鹰飞5 小时前
Leetcode会员尊享面试100题:255.验证二叉搜索树的前序遍历序列
算法·leetcode·面试
YuTaoShao5 小时前
【LeetCode 每日一题】744. 寻找比目标字母大的最小字母——(解法一)遍历
算法·leetcode·职场和发展
im_AMBER5 小时前
Leetcode 110 奇偶链表
数据结构·学习·算法·leetcode
踩坑记录7 小时前
leetcode hot100 easy 101. 对称二叉树 递归 层序遍历 bfs
算法·leetcode·宽度优先