leetcode 1594. 矩阵的最大非负积

题目如下

数据范围

示例

复制代码
本题难就难在矩阵存在负数,我们可以先思考如果矩阵每个数都大于等于0那么很简单我们只需要维护左边和上面的最大值即可。那么如果遇到负数显然要得到最大值就要和左边和右边的最小值相乘。所以这里我们维护两个二维数组用于存从(0,0)开始到(i,j)的最大值和最小值。

通过代码

cpp 复制代码
class Solution {
public:
    int maxProductPath(vector<vector<int>>& grid) {
        int n = grid.size();
        int m = grid[0].size();
        int mod = 1e9 + 7;
        vector<vector<long long>> dp1(n, vector<long long>(m));
        vector<vector<long long>> dp2(n, vector<long long>(m));
        dp1[0][0] = dp2[0][0] = grid[0][0];
        for (int i = 1; i < n; i++) {
            dp1[i][0] = dp2[i][0] = grid[i][0] * dp1[i - 1][0];
        }
        for (int i = 1; i < m; i++) {
            dp1[0][i] = dp2[0][i] = grid[0][i] * dp1[0][i - 1];
        }
        for (int i = 1; i < n; i++) {
            for (int j = 1; j < m; j++) {

                if (grid[i][j] >= 0) {
                    dp1[i][j] = max(dp1[i - 1][j], dp1[i][j - 1]) * grid[i][j];
                    dp2[i][j] = min(dp2[i - 1][j], dp2[i][j - 1]) * grid[i][j];
                } else {
                    dp1[i][j] = min(dp2[i - 1][j], dp2[i][j - 1]) * grid[i][j];
                    dp2[i][j] = max(dp1[i - 1][j], dp1[i][j - 1]) * grid[i][j];
                }
            }
        }

        if (dp1[n - 1][m - 1] < 0)
            return -1;
        return dp1[n - 1][m - 1] % mod;
    }
};

利用滚动数组思想优化后的代码

cpp 复制代码
class Solution {
public:
    int maxProductPath(vector<vector<int>>& grid) {
        int n = grid.size();
        int m = grid[0].size();
        int mod = 1e9 + 7;
        vector<long long> dp1(m);
        vector<long long> dp2(m);
        long long t1, t2;
        dp1[0] = dp2[0] = grid[0][0];
        for (int i = 1; i < m; i++) {
            dp1[i] = dp2[i] = grid[0][i] * dp1[i - 1];
        }
        for (int i = 1; i < n; i++) {
            dp1[0] = dp2[0] = dp1[0] * grid[i][0];
            for (int j = 1; j < m; j++) {
                if (grid[i][j] >= 0) {
                    dp1[j] = max(dp1[j - 1], dp1[j]) * grid[i][j];
                    dp2[j] = min(dp2[j - 1], dp2[j]) * grid[i][j];

                } else {
                    t1 = max(dp1[j - 1], dp1[j]);
                    t2 = min(dp2[j - 1], dp2[j]);
                    dp1[j] = t2 * grid[i][j];
                    dp2[j] = t1 * grid[i][j];
                }
            }
        }
        if (dp1[m - 1] < 0)
            return -1;
        return dp1[m - 1] % mod;
    }
};
相关推荐
搬砖魁首13 分钟前
基础能力系列 - 多线程2 - 条件变量
c++·rust·条件变量·原子类型·线程同步互斥
youngerwang19 分钟前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
chase_my_dream21 分钟前
C++ + SLAM 高频面试问题整理
开发语言·c++·面试
想要成为糕糕手30 分钟前
前端必修课:JavaScript 数组与数据结构底层逻辑全解析
javascript·数据结构·面试
牛油果子哥q43 分钟前
【C++ STL string 】C++ STL string 终极精讲:底层原理、内存机制、全套API、深浅拷贝、易错坑点与工程实战规范
数据库·c++
KaMeidebaby43 分钟前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
dingzd951 小时前
跨境社媒运营越到后面 越比拼账号的表达稳定性
大数据·人工智能·矩阵·内容营销
手写码匠2 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力2 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly2 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法