原題連接在這裏:https://leetcode.com/problems/stone-game-ii/html
題目:post
Alex and Lee continue their games with piles of stones. There are a number of piles arranged in a row, and each pile has a positive integer number of stones piles[i]
. The objective of the game is to end with the most stones. this
Alex and Lee take turns, with Alex starting first. Initially, M = 1
.url
On each player's turn, that player can take all the stones in the first X
remaining piles, where 1 <= X <= 2M
. Then, we set M = max(M, X)
.spa
The game continues until all the stones have been taken.code
Assuming Alex and Lee play optimally, return the maximum number of stones Alex can get.htm
Example 1:blog
Input: piles = [2,7,9,4,4] Output: 10 Explanation: If Alex takes one pile at the beginning, Lee takes two piles, then Alex takes 2 piles again. Alex can get 2 + 4 + 4 = 10 piles in total. If Alex takes two piles at the beginning, then Lee can take all three piles left. In this case, Alex get 2 + 7 = 9 piles in total. So we return 10 since it's larger.
Constraints:three
1 <= piles.length <= 100
1 <= piles[i] <= 10 ^ 4
題解:leetcode
For the current play A, if 2*M could reach the end of piles array, then A get them all.
Otherwise, A gets all - the minimum player could get. Cash value hash[i][M], which means max value from current i with value of M, in case of duplicate calculation.
Time Complexity: O(2^n). dfs takes time T(n). T(n) = O(1) + 2*M*T(n-x).
Space: O(n^2).
AC Java:
1 class Solution { 2 int [] sum; 3 int [][] hash; 4 5 public int stoneGameII(int[] piles) { 6 int n = piles.length; 7 sum = new int[n]; 8 sum[n-1] = piles[n-1]; 9 for(int i = n-2; i>=0; i--){ 10 sum[i] = sum[i+1] + piles[i]; 11 } 12 13 hash = new int[n][n]; 14 15 return dfs(piles, 0, 1); 16 } 17 18 private int dfs(int [] piles, int i, int M){ 19 if(i+2*M >= piles.length){ 20 return sum[i]; 21 } 22 23 if(hash[i][M] != 0){ 24 return hash[i][M]; 25 } 26 27 int min = Integer.MAX_VALUE; 28 for(int x = 1; x<=2*M; x++){ 29 min = Math.min(min, dfs(piles, i+x, Math.max(M, x))); 30 } 31 32 // all the left stones - minimum stones the other player could get 33 hash[i][M] = sum[i]-min; 34 return hash[i][M]; 35 } 36 }