有一个数组,其中元素有正有负,计算出当前数组中连续子数组的最大和并打印

class maxsum{
	public static int MaxSUM(int[] array){
		//传入int型数组,并得到其长度
	    int length=array.length;
	    //需要用到的中间量,即数组遍历过程中累加的和
	    int curSum=0;
	    //这是最大累加和
	    int maxSum=0;
	    //从前往后遍历数组
	    for(int i=0;i<length;i++) {
	    	//如果当前和<=0,则对当前累加和重新赋值,
	    	//这种情况是遇到了数组中含有负数和才会减少,可能使curSum值称为负值或者0
	    	if(curSum<=0) {
	    		curSum=array[i];
	    	}else {
	    		//如果不为0,说明正在累加和
	    		curSum+=array[i];
	    	}
	    	//若每次累加和大于最大和,刷新最大和,反之不刷新
	    	if(curSum>maxSum) {
	    		maxSum=curSum;
	    	}
	    }
	    //for循环结束返回最大和
	    return maxSum;
	}	
}
public class test3 {
	public static void main(String[] args) {
		int[] array= {-1,2,3};
		//maxsum类中MaxSUM方法使用staic修饰,可以用类名直接调用
		int result=maxsum.MaxSUM(array);
		System.out.println(result);
	}

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值