一、题目要求
1、输入一个整形数组,数组里有正数也有负数。
2、数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。
3、求所有子数组的和的最大值。要求时间复杂度为O(n)
二、设计思想
解决方案一:
1、通过用户输入数组容量,随机产生一个整型数组
2、将数组元素依次相加进行判断,当遇到小于0的数时停止相加(因为要求最大子数组的和,加上小于0的数会让子数组和变小)
3、遍历相加的过程中不断更新子数组的和sum以及最大值max的值
4、遍历完成后输出max值即可
解决方案二:
1、通过用户输入数组容量,随机产生一个整型数组
2、通过循环遍历所有元素求出以该元素为首节点的所有子数组的和,将其存入一个list中
3、求出list的最大值
三、源代码
由于解决方案二的复杂度高于解决方案一,这里只给出解决方案一的代码
public static int getResult(ArrayList array) {
int sum = 0;
int result = array.get(0);
for (Integer integer : array) {
if(sum<=0)
sum = integer;
else
sum += integer;
if(sum>result)
result = sum;
}
return result;
}
四、扩展<