面試題42. 連續(xù)子數(shù)組的最大和

連續(xù)子數(shù)組的最大和

題目描述

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

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


示例:

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


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

轉(zhuǎn)載來源:力扣(LeetCode)


題目分析

  • 首先,我們要達(dá)成一個共識,對于A[i],如果A[0] ~ A[i-1]的最大和小于0,那么A[i] ~ A[n]的最大和肯定與A[0] ~ A[i-1]的最大和無關(guān),因?yàn)锳[0] ~ A[i-1]的最大和是負(fù)的,只會幫倒忙
  • 如果A[0] ~ A[i-1]的最大和大于0,那么A[0] ~ A[i] 的最大和就是 A[0] ~ A[i-1]最大和+A[i],即使A[i] < 0(A[i]可以連通A[i-1]和A[i+1])
  • 每次更新A[i]的最大和,都和當(dāng)前最大和比較一下,實(shí)時更新
    fun maxSubArray(nums: IntArray): Int {
        if(nums.isEmpty()) return 0;
        var maxSum = nums[0]
        var nowSum = nums[0]
        for(i in 1 until nums.size){
            if(nowSum < 0){
                nowSum = nums[i]
            }else{
                nowSum += nums[i]
            }
            if(nowSum > maxSum){
                maxSum = nowSum
            }
        }
        return maxSum
    }

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容