99re热这里只有精品视频,7777色鬼xxxx欧美色妇,国产成人精品一区二三区在线观看,内射爽无广熟女亚洲,精品人妻av一区二区三区

動態(tài)規(guī)劃 連續(xù)子數組的最大和

2020-06-17 16:42 更新

題目

輸入一個整型數組,數組里有正數也有負數。數組中的一個或連續(xù)多個整數組成一個子數組。求所有子數組的和的最大值。

要求時間復雜度為O(n)。

示例1:

輸入: nums = [-2,1,-3,4,-1,2,1,-5,4] 輸出: 6 解釋: 連續(xù)子數組 [4,-1,2,1] 的和最大,為 6。

提示:

1 <= arr.length <= 10^5 -100 <= arr[i] <= 100

解法一

1.

max存儲最大值,cur存儲nums[i]和這一階段子序列的值,former存儲當前還未進入計算計算的也就是上一個子序列的值

class Solution {
    public int maxSubArray(int[] nums) {
        int max=nums[0],cur=0,former=0;
        for(int num:nums){
            cur=num;
            if(former>0) cur+=former;
            if(cur>max) max=cur;
            former=cur;
        }
        return max;
    }
}

解法二

利用max來代替if判斷>0

class Solution {
    public int maxSubArray(int[] nums) {
        int res = nums[0];
        for(int i = 1; i < nums.length; i++) {
            nums[i] += Math.max(nums[i - 1], 0);
            res = Math.max(res, nums[i]);
        }
        return res;
    }
}

以上內容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號