首页 > 编程语言 > 详细

最大子数组(LintCode)

时间:2015-12-06 15:50:26      阅读:216      评论:0      收藏:0      [点我收藏+]

最大子数组

给定一个整数数组,找到一个具有最大和的子数组,返回其最大和。

样例

给出数组[−2,2,−3,4,−1,2,1,−5,3],符合要求的子数组为[4,−1,2,1],其最大和为6

注意

子数组最少包含一个数

挑战

要求时间复杂度为O(n)

 

若当前和小于0,那么加到下一个数上必然会使和减小,此时抛弃这个和重新求和。当遇到一个负数时,记录下当前已知的最大和。

 

总耗时: 2721 ms

技术分享
 1 public class Solution {
 2     /**
 3      * @param nums: A list of integers
 4      * @return: A integer indicate the sum of max subarray
 5      */
 6     public int maxSubArray(int[] nums) {
 7         int sum = nums[0];
 8         int max = nums[0];
 9         for(int i = 1 ;i < nums.length ;i++) {
10             if(nums[i] < 0) {
11                 if(sum > max) max = sum;
12             }
13             
14             if(sum < 0) {
15                 sum = nums[i];
16             }else {
17                 sum+=nums[i];
18             }
19         }
20         return max>sum?max:sum;
21     }
22 }
View Code

 

最大子数组(LintCode)

原文:http://www.cnblogs.com/FJH1994/p/5023593.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!