力扣动态规划-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);
        }
    }
}

后言

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

相关推荐
一名普通的程序员几秒前
在spring boot 项目中远程调用时,如果使用subList()方法报错原因分析
java·spring boot·后端
兀行者(做个有情怀的java程序员)1 分钟前
ArrayList和LinkedList有什么区别?在什么情况下使用ArrayList更高效?
java·开发语言
大G哥4 分钟前
Java中有100万个对象,用list map泛型存储和用list对象泛型存储,那个占用空间大,为什么...
java·开发语言·数据结构·windows·list
liruiqiang0529 分钟前
机器学习 - 理解偏差-方差分解
人工智能·算法·机器学习
m0_7482338829 分钟前
JAVA程序员面试总结
java·开发语言·面试
s_little_monster37 分钟前
【Linux】进程地址空间
linux·运维·服务器·经验分享·笔记·学习·学习方法
轩源源1 小时前
数据结构——红黑树的实现
开发语言·数据结构·c++·算法·红黑树·单旋+变色·双旋+变色
Orange3015111 小时前
ES6~ES11新特性全解析
java·前端·javascript·es6
自动驾驶小卡2 小时前
线性回归计算斜率原理及C++实现
c++·算法·回归·线性回归
程序员林北北2 小时前
【Golang学习之旅】gRPC 与 REST API 的对比及应用
java·开发语言·后端·学习·云原生·golang