[剑指offer]面试题第[42]题[Leedcode][JAVA][第53题][最大子序和][动态规划][贪心][分治]
【問題描述】[第53題][最大子序和][中等]
給定一個整數數組 nums ,找到一個具有最大和的連續子數組(子數組最少包含一個元素),返回其最大和。示例:輸入: [-2,1,-3,4,-1,2,1,-5,4], 輸出: 6 解釋: 連續子數組 [4,-1,2,1] 的和最大,為 6。【解答思路】
1. 動態規劃
思路1
第 1 步:設計狀態
int[] temp = new int[len]; 記錄前i個和
第 2 步:狀態轉移方程
前一個i-1+nums[i] 和 nums[i] 作比較
temp[i] = Math.max(temp[i-1]+nums[i],nums[i]);
第 3 步:考慮初始化
temp[0] = nums[0]; max= nums[0];
第 4 步:考慮輸出
時間復雜度:O(N) 空間復雜度:O(N)
public int maxSubArray(int[] nums) {if (nums.length == 0)return 0;int[] dp = new int[nums.length];dp[0] = nums[0];int max = dp[0];for (int i=1; i<nums.length; i++){dp[i] = Math.max(dp[i-1]+nums[i],nums[i]);max= Math.max(dp[i],max);}return max;}2. 貪心算法
時間復雜度:O(N) 空間復雜度:O(1)
- sum就是這個“i之前最大子數組的和”
- 如果它大于0,則加上num就是“i+1之前最大子數組的和”
- 如果它小于0,則num本身就是“i+1之前最大子數組的和”
3. 分治算法(可忽略)
- 本題使用分治不是很理智,copy 大神的方法。
【總結】
1.Java中 Math.max 優化if-else 結構
2. 動態規劃流程
第 1 步:設計狀態
第 2 步:狀態轉移方程
第 3 步:考慮初始化
第 4 步:考慮輸出
第 5 步:考慮是否可以狀態壓縮
3. 數組初始化
- 一維數組
1.在定義時初始化。
int[] arrays = {1, 2, 3, 4, 5}; //簡化int[] arrays = new int[]{1, 2, 3, 4, 5}; //完整格式 推薦2.先定空間,隨后賦值。
- int []age = new int[10];//動態初始化for (int i = 0; i < age.length; i++) {age[i] = i;}- 二維數組
1.在定義時初始化。
double[][] a = new double[][] {{1,2,3},{4,2,7}}; double[][] b = new double[][] {{3,3},{1,1},{2,2}};2.先定空間,隨后賦值。
double [][] container = new double[3][4]; for(int i = 0; i < 3;i++) {for(int j = 0; j < 4;j++) {container[i][j] = 4.5;} }參考鏈接:https://leetcode-cn.com/problems/maximum-subarray/solution/53ti-zui-da-zi-xu-he-by-iceblood/
參考鏈接:https://leetcode-cn.com/problems/maximum-subarray/solution/hua-jie-suan-fa-53-zui-da-zi-xu-he-by-guanpengchn/
總結
以上是生活随笔為你收集整理的[剑指offer]面试题第[42]题[Leedcode][JAVA][第53题][最大子序和][动态规划][贪心][分治]的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 物联网与零边际成本共享经济
- 下一篇: ONENOTE注册CSDN