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

相关推荐
罗西的思考2 小时前
[2W字长文] 探秘Transformer系列之(23)--- 长度外推
人工智能·算法
算AI20 小时前
人工智能+牙科:临床应用中的几个问题
人工智能·算法
hyshhhh1 天前
【算法岗面试题】深度学习中如何防止过拟合?
网络·人工智能·深度学习·神经网络·算法·计算机视觉
杉之1 天前
选择排序笔记
java·算法·排序算法
烂蜻蜓1 天前
C 语言中的递归:概念、应用与实例解析
c语言·数据结构·算法
OYangxf1 天前
图论----拓扑排序
算法·图论
我要昵称干什么1 天前
基于S函数的simulink仿真
人工智能·算法
AndrewHZ1 天前
【图像处理基石】什么是tone mapping?
图像处理·人工智能·算法·计算机视觉·hdr
念九_ysl1 天前
基数排序算法解析与TypeScript实现
前端·算法·typescript·排序算法
守正出琦1 天前
日期类的实现
数据结构·c++·算法