forked from fishercoder1534/Leetcode
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy path_1043.java
34 lines (33 loc) · 1.18 KB
/
_1043.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
package com.fishercoder.solutions;
/**
* 1043. Partition Array for Maximum Sum
*
* Given an integer array A, you partition the array into (contiguous) subarrays of length at most K. After partitioning, each subarray has their values changed to become the maximum value of that subarray.
* Return the largest sum of the given array after partitioning.
*
* Example 1:
* Input: A = [1,15,7,9,2,5,10], K = 3
* Output: 84
* Explanation: A becomes [15,15,15,9,10,10,10]
*
* Note:
* 1 <= K <= A.length <= 500
* 0 <= A[i] <= 10^6
* */
public class _1043 {
public static class Solution1 {
/**credit: https://leetcode.com/problems/partition-array-for-maximum-sum/discuss/290863/JavaC%2B%2BPython-DP*/
public int maxSumAfterPartitioning(int[] A, int K) {
int N = A.length;
int[] dp = new int[N];
for (int i = 0; i < N; i++) {
int curMax = 0;
for (int k = 1; k <= K && i - k + 1 >= 0; k++) {
curMax = Math.max(curMax, A[i - k + 1]);
dp[i] = Math.max(dp[i], (i >= k ? dp[i - k] : 0) + curMax * k);
}
}
return dp[N - 1];
}
}
}