题目:给定一个数组,其中元素可正可负,求其中最大连续子序列的和。
这题是一道非常经典的面试题,会经常出现在各种面试中,具体有好几种不同时间复杂度的解法,那么最好的方法是用动态规划方法来求解。
第一种:时间复杂度为O(n^3)
暴力法求解。三层循环,从起点和终点开始,第一层循环确定起点,第二层循环确定终点,第三层循环在起点和终点之间遍历。
public static int maxSubArray(int[] nums)
{
int thisSum,maxSum = Integer.MIN_VALUE,i,j,k;
int length = nums.length;
for(i = 0; i < length; i++)
{
for(j = i; j < length; j++)
{
thisSum = 0;
for(k = i; k <= j; k++)
{
thisSum += nums[k];
}
if(thisSum > maxSum)
maxSum = thisSum;
}
}
return maxSum;
}
这是最糟糕的做法,时间复杂度最高,不好,直接舍弃。
第二种做法