编程之美--子数组中的最大乘积

本文介绍了一种求解子数组最大乘积的算法,通过两种不同方法实现:一种是枚举所有可能的子数组组合(O(n²)),另一种则是采用空间换时间策略达到O(n)的时间复杂度。
import java.util.Arrays;

/**
 * 求一个数组中子数组的最大乘积,子数组个数为n-1
 * @author Administrator
 *
 */
public class SubArrayMaxProduct {
    /**
     * 因为数据个数为n-1,我们可以枚举  O(n2);
     * @param array
     * @param len
     */
    public static void execute(int[]array,int len){
	int min = 100000;
	for(int i=0;i<len;i++){
	    int cursor = 1;
	    for(int j=0;j<len;j++){
		if(j!=i)
		   cursor *= array[j];
	    }
	    if(min>cursor) min = cursor;
	}
	System.out.println(min);
    }
    /**
     * 我们可以以空间来换时间,r[i]= a[0]*a[1]*...*a[i-1]*a[i+1]*...*a[n];
     * s[i] = a[0]*a[1]*...*a[i];
     * e[i] = a[i]*...*a[n]
     * r[i] = s[i-1]*e[i+1]
     * 所以我们要把所有的 s[] e [] 都求出来 ,此算法为 O(n);
     * @param array
     * @param len
     */
    public static void execute2(int[]array,int len){
	int[] s = new int[len]; s[0] = array[0];
	int[] e = new int[len]; e[len-1] = array[len-1]; 
	for(int i=1,j=len-2;i<len;i++,j--){
	    s[i] = s[i-1]* array[i];
	    e[j] = e[j+1]*array[j];
	}
	
	// 遍历找最小的
	int min = e[1]>s[len-2]?s[len-2]:e[1];
	for(int i=1;i<len-1;i++){
	    int p = s[i-1]*e[i+1];
	    if(p<min) min = p;
	}
	System.out.println(min);
    }
    public static void main(String args[]){
	int[]array = {2,5,7,2,6,5};
	execute(array,array.length);
	execute2(array,array.length);
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值