-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstoneGame.txt
44 lines (34 loc) · 1.42 KB
/
stoneGame.txt
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
35
36
37
38
39
40
41
42
43
44
1686. Stone Game VI
Alice and Bob take turns playing a game, with Alice starting first.
There are n stones in a pile. On each player's turn,
they can remove a stone from the pile and receive points based on the stone's value.
Alice and Bob may value the stones differently.
You are given two integer arrays of length n, aliceValues and bobValues. Each aliceValues[i] and bobValues[i] represents how Alice and Bob,
respectively, value the ith stone.
The winner is the person with the most points after all the stones are chosen.
If both players have the same amount of points, the game results in a draw. Both players will play optimally.
Both players know the other's values.
Determine the result of the game, and:
If Alice wins, return 1.
If Bob wins, return -1.
If the game results in a draw, return 0.
class Solution {
public:
int stoneGameVI(vector<int>& aliceValues, vector<int>& bobValues) {
priority_queue<pair<int, pair<int, int>>> pq;
int alice = 0 , bob = 0;
for(int i = 0 ; i < aliceValues.size() ; i++){
pq.push({aliceValues[i]+bobValues[i], {aliceValues[i],bobValues[i]}});
}
while(pq.size()){
alice +=pq.top().second.first;
pq.pop();
if(pq.size()){
bob += pq.top().second.second, pq.pop();
}
}
if(bob == alice) return 0;
else if(bob > alice) return -1;
else return 1;
}
};