Description
You start with an initial power of power
, an initial score of 0
, and a bag of tokens given as an integer array tokens
, where each tokens[i]
donates the value of token_i_.
Your goal is to maximize the total score by strategically playing these tokens. In one move, you can play an unplayed token in one of the two ways (but not both for the same token):
- Face-up: If your current power is at least
tokens[i]
, you may play token_i_, losingtokens[i]
power and gaining1
score. - Face-down: If your current score is at least
1
, you may play token_i_, gainingtokens[i]
power and losing1
score.
Return the maximum possible score you can achieve after playing any number of tokens.
Example 1:
Input: tokens = [100], power = 50
Output: 0
Explanation**:** Since your score is 0
initially, you cannot play the token face-down. You also cannot play it face-up since your power (50
) is less than tokens[0]
(100
).
Example 2:
Input: tokens = [200,100], power = 150
Output: 1
Explanation: Play token_1_ (100
) face-up, reducing your power to 50
and increasing your score to 1
.
There is no need to play token_0_, since you cannot play it face-up to add to your score. The maximum score achievable is 1
.
Example 3:
Input: tokens = [100,200,300,400], power = 200
Output: 2
Explanation: Play the tokens in this order to get a score of 2
:
- Play token_0_ (
100
) face-up, reducing power to100
and increasing score to1
. - Play token_3_ (
400
) face-down, increasing power to500
and reducing score to0
. - Play token_1_ (
200
) face-up, reducing power to300
and increasing score to1
. - Play token_2_ (
300
) face-up, reducing power to0
and increasing score to2
.
The maximum score achievable is 2
.
Constraints:
0 <= tokens.length <= 1000
0 <= tokens[i], power < 104
Code
Time Complexity: , Space Complexity:
Greedy Intuition:當 power 不夠時,playing face down 都是 cost -1,所以當然要能夠獲得越多的 power 越好,所以使用 two pointer 從尾巴開始。