一開始題目沒有看清楚,覺得仍是求和,可是這一題實際上是求乘積,那麼相對於求和的題目,求乘積須要注意的有兩點:數組
解題的思想以下:code
代碼以下:leetcode
javapublic class Solution { public int maxProduct(int[] A) { int max = A[0], length = A.length; int begin = 0, end, product; while (begin < length && A[begin] == 0) { begin++; } if (begin == length) return 0; end = begin + 1; product = A[begin]; while (end < length) { if (A[end] == 0) { max = Math.max(max, Math.max(0, countMax(begin, end, A, product))); begin = end + 1; while (begin < length && A[begin] == 0) { begin++; } if (begin == length) break; product = A[begin]; end = begin + 1; } else { product *= A[end++]; } } if (begin != length) max = Math.max(max, countMax(begin, length, A, product)); return max; } private int countMax(int begin, int end, int[] A, int product) { if (product > 0 || end - begin == 1) { return product; } int index = begin; int preProduct = 1, sufProduct = 1; while (index < end - 1 && A[index] > 0) { preProduct *= A[index]; index++; } preProduct *= A[index]; index = end - 1; while (begin < index && A[index] > 0) { sufProduct *= A[index]; index--; } sufProduct *= A[index]; return Math.max(product / preProduct, product / sufProduct); } }