力扣动态规划-23【算法学习day.117】

前言

###我做这类文章一个重要的目的还是记录自己的学习过程,我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非常非常高滴!!!


习题

1.矩阵的最大非负积

题目链接: 1594. 矩阵的最大非负积 - 力扣(LeetCode)

题面:

附上大佬代码:

java 复制代码
class Solution {
    public int maxProductPath(int[][] grid) {
        final int MOD = 1000000000 + 7;
        int m = grid.length, n = grid[0].length;
        // 初始化 maxgt 和 minlt 数组,保存第一行的值
        long[] maxgt = new long[n];
        long[] minlt = new long[n];
        maxgt[0] = minlt[0] = grid[0][0];
        // 初始化第一的 maxgt 和 minlt
        for (int i = 1; i < n; i++) {
            maxgt[i] = maxgt[i - 1] * grid[0][i];
            minlt[i] = minlt[i - 1] * grid[0][i];
        }
        // 从第二行开始处理
        for (int i = 1; i < m; i++) {
            // 更新第一列的 maxgt 和 minlt
            maxgt[0] *= grid[i][0];
            minlt[0] *= grid[i][0];
            for (int j = 1; j < n; j++) {
                if (grid[i][j] >= 0) {
                    maxgt[j] = Math.max(maxgt[j], maxgt[j - 1]) * grid[i][j];
                    minlt[j] = Math.min(minlt[j], minlt[j - 1]) * grid[i][j];
                } else {
                    long tempMax = maxgt[j]; // 暂存当前值
                    maxgt[j] = Math.min(minlt[j], minlt[j - 1]) * grid[i][j];
                    minlt[j] = Math.max(tempMax, maxgt[j - 1]) * grid[i][j];
                }
            }
        }
        // 最终结果为右下角的 maxgt
        if (maxgt[n - 1] < 0) {
            return -1;
        } else {
            return (int) (maxgt[n - 1] % MOD);
        }
    }
}

后言

上面是动态规划相关的习题,共勉

相关推荐
这儿有一堆花33 分钟前
比特币:固若金汤的数字堡垒与它的四道防线
算法·区块链·哈希算法
BillKu34 分钟前
Java + Spring Boot + Mybatis 实现批量插入
java·spring boot·mybatis
YuTaoShao35 分钟前
Java八股文——集合「Map篇」
java
客卿12339 分钟前
力扣100-移动0
算法·leetcode·职场和发展
有梦想的攻城狮3 小时前
maven中的maven-antrun-plugin插件详解
java·maven·插件·antrun
CM莫问4 小时前
<论文>(微软)WINA:用于加速大语言模型推理的权重感知神经元激活
人工智能·算法·语言模型·自然语言处理·大模型·推理加速
计信金边罗6 小时前
是否存在路径(FIFOBB算法)
算法·蓝桥杯·图论
MZWeiei6 小时前
KMP 算法中 next 数组的构建函数 get_next
算法·kmp
硅的褶皱6 小时前
对比分析LinkedBlockingQueue和SynchronousQueue
java·并发编程
MoFe16 小时前
【.net core】天地图坐标转换为高德地图坐标(WGS84 坐标转 GCJ02 坐标)
java·前端·.netcore