Given a fixed-size array containing
One approach is to generate all possible sub-arrays and return the maximum product after evaluating the product of each sub-array. However, this is a very inefficient solution as it will take
In this Answer, we'll explore how a more efficient solution can be implemented for this task, which takes
To efficiently solve this problem, we need to keep track of 3 products while iterating through the array. The products are as follows:
The current maximum product (
The current minimum product (
The overall largest product encountered (
The algorithm is as follows:
Initialize
Begin iterating the array.
If the current element is negative, swap the values of
Update
Once the array is completely traversed, return
The example below visually demonstrates how this algorithm works:
The code below implements the logic discussed above in C++ and Python:
#include <iostream>using namespace std;int maxProductofSubarray(int* arr, int N){// initializing prod_max, prod_min and overall_maxint prod_max = arr[0];int prod_min = arr[0];int overall_max = arr[0];for(int i=0 ; i<N; i++){if(arr[i] < 0) // checking if negative{int temp = prod_max ;prod_max = prod_min ;prod_min = temp ;}// prod_max = max(arr[i] , arr[i] * prod_max)if(arr[i] > arr[i]*prod_max){prod_max = arr[i];}else{prod_max = arr[i] * prod_max ;}// prod_min = min(arr[i] , arr[i] * prod_min)if(arr[i] < arr[i]*prod_min){prod_min = arr[i];}else{prod_min = arr[i] * prod_min ;}// overall_max = max(overall_max , prod_max)if(prod_max > overall_max){overall_max = prod_max ;}else{overall_max = prod_min ;}}return overall_max ;}int main(){int arr[6] = {1, 2, -3, 0, -4, -5};int N = 6;int max_prod_of_a_subarray = maxProductofSubarray(arr , N);cout << "The maximum product of a sub-array is: " << max_prod_of_a_subarray << endl ;return 0;}
The important lines in the code are explained below:
Lines 6 – 8: We initialize prod_max
, prod_min
and overall_max
to arr[0]
.
Lines 20 – 27: We update prod_max
such that prod_max
is max(arr[i], arr[i] * prod_max)
.
Lines 30 – 37: We update prod_min
such that prod_min
is min(arr[i], arr[i] * prod_min)
.
Lines 40 – 47: We update overall_max
such that overall_max
is max(overall_max, arr[i] * overall_max)
.
Free Resources