Leetcode 152 乘積最大子陣列

2021-10-04 19:47:22 字數 462 閱讀 2514

迴圈到i時,考慮以nums[i]結尾的連續陣列乘積

考慮到nums[i]可能為負數,使最小值反轉為最大值。要記錄上乙個點最小值和最大值

要求連續,因此不需要陣列,只需要四個變數,上乙個點的min和max,該點的min和max。

狀態轉換方程

now_max=max(nums[i],max(nums[i]*dp_min,nums[i]*dp_max)); now_min=min(nums[i],min(nums[i]*dp_max,nums[i]*dp_min));

class

solution

return maxval;}}

;

Leetcode 152 乘積最大子串行

原題描述 找出乙個序列中乘積最大的連續子串行 該序列至少包含乙個數 例如,給定序列 2,3,2,4 其中乘積最大的子串行為 2,3 其乘積為6。解答 1.暴力搜尋 o n 2 沒有ac 超時 class solution return max 2.動態規劃思想,max min 每有乙個新的數字加入,...

Leetcode 152 乘積最大子串行

給定乙個整數陣列nums,找出乙個序列中乘積最大的連續子串行 該序列至少包含乙個數 示例 1 輸入 2,3,2,4 輸出 6解釋 子陣列 2,3 有最大乘積 6。示例 2 輸入 2,0,1 輸出 0解釋 結果不能為 2,因為 2,1 不是子陣列。這裡用動態規化的方法,即dp i 為以i結尾乘積最大連...

leetcode152 乘積最大子串行

給定乙個整數陣列 nums 找出乙個序列中乘積最大的連續子串行 該序列至少包含乙個數 示例 1 輸入 2,3,2,4 輸出 6 解釋 子陣列 2,3 有最大乘積 6。示例 2 輸入 2,0,1 輸出 0 解釋 結果不能為 2,因為 2,1 不是子陣列。用三個變數分別記錄最大值,到之前乙個數的最大值和...