comments | difficulty | edit_url | tags | ||||
---|---|---|---|---|---|---|---|
true |
Medium |
|
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]
denotes the value of tokeni.
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 tokeni, losingtokens[i]
power and gaining1
score. - Face-down: If your current score is at least
1
, you may play tokeni, 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 token1 (100
) face-up, reducing your power to 50
and increasing your score to 1
.
There is no need to play token0, 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 token0 (
100
) face-up, reducing power to100
and increasing score to1
. - Play token3 (
400
) face-down, increasing power to500
and reducing score to0
. - Play token1 (
200
) face-up, reducing power to300
and increasing score to1
. - Play token2 (
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
There are two ways to use tokens: one is to consume energy to gain points, and the other is to consume points to gain energy. Obviously, we should consume as little energy as possible to gain as many points as possible.
Therefore, we can sort the tokens by the amount of energy they consume, and then use two pointers: one moving from left to right and the other from right to left. In each iteration, we try to consume energy to gain points as much as possible, and then update the maximum score. If the current energy is not enough to consume the current token, we try to consume the current token using points. If the points are not enough to consume the current token, we stop the iteration.
The time complexity is
class Solution:
def bagOfTokensScore(self, tokens: List[int], power: int) -> int:
tokens.sort()
ans = score = 0
i, j = 0, len(tokens) - 1
while i <= j:
if power >= tokens[i]:
power -= tokens[i]
score, i = score + 1, i + 1
ans = max(ans, score)
elif score:
power += tokens[j]
score, j = score - 1, j - 1
else:
break
return ans
class Solution {
public int bagOfTokensScore(int[] tokens, int power) {
Arrays.sort(tokens);
int ans = 0, score = 0;
for (int i = 0, j = tokens.length - 1; i <= j;) {
if (power >= tokens[i]) {
power -= tokens[i++];
ans = Math.max(ans, ++score);
} else if (score > 0) {
power += tokens[j--];
--score;
} else {
break;
}
}
return ans;
}
}
class Solution {
public:
int bagOfTokensScore(vector<int>& tokens, int power) {
sort(tokens.begin(), tokens.end());
int ans = 0, score = 0;
for (int i = 0, j = tokens.size() - 1; i <= j;) {
if (power >= tokens[i]) {
power -= tokens[i++];
ans = max(ans, ++score);
} else if (score > 0) {
power += tokens[j--];
--score;
} else {
break;
}
}
return ans;
}
};
func bagOfTokensScore(tokens []int, power int) (ans int) {
sort.Ints(tokens)
i, j := 0, len(tokens)-1
score := 0
for i <= j {
if power >= tokens[i] {
power -= tokens[i]
i++
score++
ans = max(ans, score)
} else if score > 0 {
power += tokens[j]
j--
score--
} else {
break
}
}
return
}
function bagOfTokensScore(tokens: number[], power: number): number {
tokens.sort((a, b) => a - b);
let [i, j] = [0, tokens.length - 1];
let [ans, score] = [0, 0];
while (i <= j) {
if (power >= tokens[i]) {
power -= tokens[i++];
ans = Math.max(ans, ++score);
} else if (score) {
power += tokens[j--];
score--;
} else {
break;
}
}
return ans;
}