定个小目标之刷LeetCode热题(27)

这道题,我们可以使用动态规划,假设数组元素范围是>=0,那么递推关系式表示为

imax = MAX(imax * nums[i], nums[i]),由于本题数组元素范围是整数,即存在负数,最大可能变最小,最小可能变最大,所以除了维护一个max,还需要维护一个imin,imin = MIN(imin * nums[i], nums[i]),在遇到负数时,需要将imax和imin进行交换,画草图如下

知道了思路,代码很容易就能敲出来,代码如下所示

java 复制代码
class Solution {
    public int maxProduct(int[] nums) {
        if (nums.length == 1)
            return nums[0];
        int imax = 1, imin = 1, max = Integer.MIN_VALUE;
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] < 0) {
                int temp = imax;
                imax = imin;
                imin = temp;
            }
            imax = Math.max(imax * nums[i], nums[i]);
            imin = Math.min(imin * nums[i], nums[i]);
            max = Math.max(max, imax);
        }
        return max;
    }
}

题目链接:题单 - 力扣(LeetCode)全球极客挚爱的技术成长平台

相关推荐
SuperCandyXu20 小时前
P3205 [HNOI2010] 合唱队-普及+/提高
c++·算法·洛谷
_OP_CHEN20 小时前
数据结构(C语言篇):(十二)实现顺序结构二叉树——堆
c语言·数据结构·算法·二叉树·学习笔记··顺序结构二叉树
Yingjun Mo21 小时前
1. 统计推断-基于神经网络与Langevin扩散的自适应潜变量建模与优化
人工智能·神经网络·算法·机器学习·概率论
地平线开发者1 天前
征程 6 | 灰度图部署链路介绍
算法·自动驾驶
地平线开发者1 天前
手撕大模型|KVCache 原理及代码解析
算法·自动驾驶
共享家95271 天前
经典动态规划题解
算法·leetcode·动态规划
Pluchon1 天前
硅基计划3.0 Map类&Set类
java·开发语言·数据结构·算法·哈希算法·散列表
☼←安于亥时→❦1 天前
PyTorch之张量创建与运算
人工智能·算法·机器学习
子豪-中国机器人1 天前
枚举算法和排序算法能力测试
开发语言·c++·算法
qiuyunoqy1 天前
基础算法之二分算法 --- 2
算法