码迷,mamicode.com
首页 > 编程语言 > 详细

最大子数组(LintCode)

时间:2015-12-06 15:52:19      阅读:152      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!