描述
给定一个数组arr,返回子数组的最大累加和
例如,arr = [1, -2, 3, 5, -2, 6, -1],所有子数组中,[3, 5, -2, 6]可以累加出最大的和12,所以返回12.
题目保证没有全为负数的数据
[要求]时间复杂度为O(n)O(n),空间复杂度为O(1)O(1)
示例1
输入:[1, -2, 3, 5, -2, 6, -1]
返回值:12
备注:
分析:
创建一个数组a,长度为原数组长度,不同位置数字a[i]代表0...i上最大连续子序列和,a[0]=arr[0]设置一个最大值max,初始值为数组中的第一个数字。当进来一个新的数字arr[i+1]时,判断到他前面数字子序列和a[i]+arr[i+1]跟arr[i+1]哪个大,前者大就保留前者,后者大就说明前面连续数字加起来都不如后者一个新进来的数字大,前面数字就可以舍弃,从arr[i+1]开始,每次比较完都跟max比较一下,最后的max就是最大值。
代码:
public int maxsumofSubarray (int[] arr) {
// write code here
int len = arr.length;
int max = arr[0];
int sum = arr[0];
for(int i = 1;i < len;i++){
sum = arr[i] > sum + arr[i]?arr[i]:sum+arr[i];
max = max > sum?max:sum;
}
return max;
}