算法实践篇-求最大子数组

package com.sort.divid;

/**
 * 求最大子数组
 * @author Administrator
 *nlogn
 */
public class MaxSubArray {
	private static int[] findMaxCrossSubArray(int [] data,int left,int middle,int right){
		int [] result=new int[3];
		int leftmax=data[middle];
		int sum=leftmax;
		int leftIndex=middle;
		for(int i=middle-1;i>=left;i--){
			sum=sum+data[i];
			if(sum>leftmax){
				leftmax=sum;
				leftIndex=i;
			}
		}
		int rightmax=data[middle+1];
		sum=rightmax;
		int rightIndex=middle+1;
		for(int i=middle+2;i<=right;i++){
			sum=sum+data[i];
			if(sum>rightmax){
				rightmax=sum;
				rightIndex=i;
			}
		}
		result[0]=leftmax+rightmax;
		result[1]=leftIndex;
		result[2]=rightIndex; 
		return result;
	}
	
	private static int[] findMaxSubArray(int []data,int left,int right){
		int [] result=new int[3];
		if(left==right){
			result[0]=data[left];
			result[1]=left;
			result[2]=right;
			return result;
		}
		int middle=(left+right)/2;
		int[] leftResult=findMaxSubArray(data,left,middle);
		int [] rightResult=findMaxSubArray(data,middle+1,right);
		int []crossResult=findMaxCrossSubArray(data,left,middle,right);
		if(leftResult[0]>rightResult[0]&&leftResult[0]>crossResult[0]){
			return leftResult;
		}else if(rightResult[0]>leftResult[0]&&rightResult[0]>crossResult[0]){
			return rightResult;
		}else{
			return crossResult;
		}
	}

	public static void main(String[] args) {
		int[] data=new int[]{-1,2,9,11,-20,9,6,22,-8,9,1};
		for(int i=0;i<data.length;i++){
			System.out.print(data[i]+" ");
		}
		System.out.println();
		int []result=findMaxSubArray(data,0,data.length-1);;
		for(int i=0;i<result.length;i++){
			System.out.print(result[i]+" ");
		}
		System.out.println();

	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hxpjava1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值