題目
For example, given the array [-2,1,-3,4,-1,2,1,-5,4]
,
the contiguous subarray [4,-1,2,1]
has the largest sum = 6
.
中文題意:在給定數組中找出具有最大和的連續子序列,並返回該最大和。
例:給定數組[-2, 1, -3, 4, -1, 2, 1, -5, 4],符合題意的子序列爲[4, -1, 2, 1],最大和爲6
分析
解答
class Solution {
public:
int maxSubArray(vector<int>& nums) {
int length=nums.size();
if(length==0)
return 0;
int result=nums[0];
int sum=0;
for(int i=0;i<length;i++){
sum=sum+nums[i];
if(sum>result){
result=sum;
}
if(sum<=0){
sum=0;
}
}
return result;
}
};
時間複雜度爲O(n),其中n爲數組長度。