连续子数组的最大和
本题的动态规划解法,待完成。
题目
输入一个整型数组,数组里有正数也有负数。数组中一个或连续的多个整/数组成一个子数组。求所有子数组的和的最大值。要求时间复杂度为O(n)。
思路
分析规律,从第一个数字开始累加,若走到某一个数字时,前面的累加和为负数,说明不能继续累加了,要从当前数字重新开始累加。在累加过程中,将每次累加和的最大值记录下来,遍历完成后,返回该数字。
测试用例
功能测试(输入数组有正有负,全负数,全正数)
特殊输入测试(null)
java代码
1 |
|
卢德鹏的算法刷题札记
本题的动态规划解法,待完成。
输入一个整型数组,数组里有正数也有负数。数组中一个或连续的多个整/数组成一个子数组。求所有子数组的和的最大值。要求时间复杂度为O(n)。
分析规律,从第一个数字开始累加,若走到某一个数字时,前面的累加和为负数,说明不能继续累加了,要从当前数字重新开始累加。在累加过程中,将每次累加和的最大值记录下来,遍历完成后,返回该数字。
功能测试(输入数组有正有负,全负数,全正数)
特殊输入测试(null)
1 |
|