【Hot100】LeetCode—152. 乘积最大子数组

目录

  • 题目
  • [1- 思路](#1- 思路)
  • [2- 实现](#2- 实现)
    • [⭐152. 乘积最大子数组------题解思路](#⭐152. 乘积最大子数组——题解思路)
  • [3- ACM 实现](#3- ACM 实现)

题目


1- 思路

动规五部曲


2- 实现

⭐152. 乘积最大子数组------题解思路

java 复制代码
class Solution {
    public int maxProduct(int[] nums) {
        // 初始化答案以及以第一个元素结尾的最大和最小乘积
        int ans = nums[0];
        int max_i = nums[0];
        int min_i = nums[0];

        // 遍历数组从第二个元素开始
        for (int i = 1; i < nums.length; i++) {
            // 当 nums[i] 为负数时,max_i 和 min_i 需要交换
            if (nums[i] < 0) {
                int temp = max_i;
                max_i = min_i;
                min_i = temp;
            }

            // 更新 max_i 和 min_i
            max_i = Math.max(nums[i], max_i * nums[i]);
            min_i = Math.min(nums[i], min_i * nums[i]);

            // 更新答案
            ans = Math.max(ans, max_i);
        }

        return ans;
    }
}

3- ACM 实现

java 复制代码
public class maxProduct {

    public static int maxProduct(int[] nums){
        // 1. 定义dp状态
        int ans = 0;
        // 当前最小值乘积,当前最大乘积
        int maxF = nums[0];
        int minF = nums[0];

        // 2.递推公式
        // 如果 nums[i]<0
        // maxF = Math.max(maxF*nums[i],nums[i]);
        // minF = Math.min(minF*nums[i],nums[i]);


        // 此时 要交换 maxF 和 minF 才能保证乘积最大
        for(int i = 1 ; i < nums.length;i++){
            if(nums[i]<0){
                int tmp = maxF;
                maxF = minF;
                minF = tmp;
            }
             maxF = Math.max(maxF*nums[i],nums[i]);
             minF = Math.min(minF*nums[i],nums[i]);
             ans = Math.max(ans,maxF);
        }
        return ans;
    }



    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("输入数组长度");
        int n = sc.nextInt();
        int[] nums = new int[n];
        for(int i = 0 ; i < n;i++){
            nums[i] = sc.nextInt();
        }
        System.out.println("结果是"+maxProduct(nums));
    }
}

相关推荐
爱吃涮毛肚的肥肥(暂时吃不了版)3 分钟前
项目班——0510——JSON网络封装
c++·算法·json
liang_202616 分钟前
【HT周赛】T3.二维平面 题解(分块:矩形chkmax,求矩形和)
数据结构·笔记·学习·算法·平面·总结
緈福的街口18 分钟前
【leetcode】2900. 最长相邻不相等子序列 I
算法·leetcode·职场和发展
易只轻松熊19 分钟前
C++(20): 文件输入输出库 —— <fstream>
开发语言·c++·算法
远瞻。40 分钟前
【论文阅读】人脸修复(face restoration ) 不同先验代表算法整理
论文阅读·算法
进击的小白菜1 小时前
LeetCode 153. 寻找旋转排序数组中的最小值:二分查找法详解及高频疑问解析
数据结构·算法·leetcode
dog2501 小时前
BBR 的 buffer 动力学观感
人工智能·算法
冲帕Chompa4 小时前
图论part10 bellman_ford算法
数据结构·算法·图论
緈福的街口4 小时前
【leetcode】144. 二叉树的前序遍历
算法·leetcode
GG不是gg4 小时前
排序算法之基础排序:冒泡,选择,插入排序详解
数据结构·算法·青少年编程·排序算法