天天看點

#yyds幹貨盤點# leetcode-連續數列

動态規劃,确定子問題即可
package com.leetcode.leetcode.licm;

/**
 * @description:
 * @author: licm
 * @create: 2021-07-27 09:51
 **/
public class Lc面試題1617連續數列 {

    /**
     * dp
     * <p>
     * 1. 确定dp含義 目前下标對應的最大值
     * 2. 遞推公式 Math.max(nums[i],dp[i-1]+nums[i])
     * 3. 初始化
     * 4。确定周遊順序
     * 4. 推導結果
     *
     * @param nums
     * @return
     */
    public static int maxSubArray(int[] nums) {
        if (nums.length == 0) {
            return 0;
        }
        int[] dp = new int[nums.length];
        dp[0] = nums[0];
        for (int i = 1; i < nums.length; i++) {
            dp[i] = Math.max(nums[i], dp[i - 1] + nums[i]);
        }
        int res = Integer.MIN_VALUE;
        for (int i = 0; i < dp.length; i++) {
            res = res < dp[i] ? dp[i] : res;
        }
        return res;
    }

    public static void main(String[] args) {
        int[] nums = {-2, 1, -3, 4, -1, 2, 1, -5, 4};
        System.out.println(maxSubArray(nums));
    }
}