Maximum Product Subarray(最大连续乘积子序列)

Find the contiguous subarray within an array (containing at least one number) which has the largest product.

For example, given the array [2,3,-2,4],
the contiguous subarray [2,3] has the largest product = 6.


思路:类似最大和连续子序列那样,不过除了记录最大乘积,我们还要记录最小的乘积。这里我分三种情况:

1.A[i]>0。

2.A[i]<0。p[i].max=Max(p[i-1].min*A[i],A[i]);也就是看看前i-1项的最小值是不是负数,若是负数,则p[i].max=p[i-1]*A[i](负负得正);若不是负数,则p[i]=A[i]。

3.若A[i]=0,则以0为结尾的序列的乘积的最大值和最小值一定都是0。

代码:

class Solution {
private:
struct pro{
    int max;
    int min;
};
public:
    int Max(int a,int b){
        return a>b?a:b;
    }
    int Min(int a,int b){
        return a<b?a:b;
    }
    int maxProduct(int A[], int n) {     
        struct pro p[n];
        p[0].max=A[0];
        p[0].min=A[0];
        for (int i=1;i<n;++i)
        {
            if(A[i]>0){
                p[i].max=Max(p[i-1].max*A[i],A[i]);
                p[i].min=Min(p[i-1].min*A[i],A[i]);
            }
            else if(A[i]<0){
                p[i].max=Max(p[i-1].min*A[i],A[i]);
                p[i].min=Min(p[i-1].max*A[i],A[i]);
            }
            else{
                p[i].max=0;
                p[i].min=0;
            }
        }
        int res=p[0].max;
        for (int i=1;i<n;++i)
        {
            if(p[i].max>res)
                res=p[i].max;
        }
        return res;
    }
};
原文地址:https://www.cnblogs.com/fightformylife/p/4090314.html