当前位置: 首页 > news >正文

leetcode 1594. 矩阵的最大非负积

题目如下
在这里插入图片描述

数据范围
在这里插入图片描述
示例
在这里插入图片描述

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

通过代码

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;
    }
};

在这里插入图片描述

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

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;
    }
};

在这里插入图片描述

相关文章:

  • Java8适配的markdown转换html工具(FlexMark)
  • STL介绍1:vector、pair、string、queue、map
  • 深度学习之图像回归(二)
  • python windows services demo
  • 条款13:以对象管理资源
  • C++ 的时间库之二:Ratio
  • 【Elasticsearch】分页查询
  • 自然语言处理入门1——单词的表示和距离
  • el-table的hasChildren不生效?子级没数据还显示箭头号?树形数据无法展开和收缩
  • 数据治理中 大数据处理一般都遵循哪些原则
  • idea日常报错之UTF-8不可映射的字符
  • 关于如何利用群晖Docker搭建Project Zomboid(僵尸毁灭工程)私人服务器-保姆级教程
  • P2814 家谱 C++
  • MVTEC数据集笔记
  • 第435场周赛:奇偶频次间的最大差值 Ⅰ、K 次修改后的最大曼哈顿距离、使数组包含目标值倍数的最少增量、奇偶频次间的最大差值 Ⅱ
  • 【进阶】微服务
  • Unity合批处理优化内存序列帧播放动画
  • 深度优先搜索
  • deepseek R1基本原理解读与系列论文简介
  • 【ISO 14229-1:2023 UDS诊断(ECU复位0x11服务)测试用例CAPL代码全解析⑫】
  • 马上评丨全民定制公交,打开城市出行想象空间
  • 2025年4月份CPI环比由降转涨,核心CPI涨幅稳定
  • 巴基斯坦关闭全部领空
  • A股低开高走全线上涨:军工股再度领涨,两市成交12934亿元
  • 东亚社会的“苦难诗学”:从《苦尽柑来遇见你》说起
  • 上海加力提速推进优化营商环境,明确“十大攻坚突破任务”