Maximum Product Subarray (Modified Kadane's Algorithm)

Posted by on Mar 31, 2024

Given an integer array arr[] that contains n integers (positive, negative or zero).

The task is to find a contiguous non-empty subarray within the array that has the largest product.

Input: 2,3,-2,4
Output: 6

Input: 6, -3, -10, 0, 2
Output: 180


Solutions

Method 1: Modified Kadane's Algorithm

This approach is similar to the Largest sum contiguous sub-array (Kadane's Algorithm).

The only thing to keep in mind here is that a negative minimum product ending with the previous element multiplied by the current element (if negative) can also yield a maximum product.

Therefore, we need to maintain an extra variable "min_ending_here" to store the minimum product, along with "max_ending_here" and "max_so_far".

For every iteration, the maximum number ending at that index will be the maximum(arr[i], max_ending_here * arr[i], min_ending_here[i]*arr[i]).

Similarly, the minimum number ending here will be the minimum of these 3.

Finally, "max_so_far" will be the maximum of "max_ending_here" and "max_so_far".

This solution works for "all-positive", "all-negative" as well as "positive-negative-zero" combinations.

Complexity

The time complexity of this solution is O(n) and space complexity is O(1).

Related


Minimize the difference between the heights of smallest and highest tower

Find duplicates in O(n) time and O(n) extra space.

Move all negative numbers to beginning of the array

Segregate 0s and 1s in an array (Sort an array of 0s and 1s)

Find largest sum contiguous sub-array (Kadane's Algorithm)

Find maximum and minimum element of an array

Alternating +ve & -ve in array in O(1) time (maintaining order)

Find duplicates in O(n) time and O(1) extra space

Segregate 0s, 1s and 2s in an array (Sort an array of 0s, 1s and 2s)

Program to right rotate an array by 'k' elements