Two players A and B have a list of n
integers each. They both want to maximize the subtraction between their score and their opponent's score.
In one turn, a player can either add to his score any element from his list (assuming his list is not empty), the element is removed from the list afterward. Or remove an element from his opponent's list (assuming his opponent's list is not empty).
Note, that in case there are equal elements in the list only one of them will be affected in the operations above. For example, if there are elements {1,2,2,3}
in a list and you decided to choose 2 for the next turn, only a single instance of 2
will be deleted (and added to the score, if necessary).
The player A starts the game and the game stops when both lists are empty. Find the difference between A's score and B's score at the end of the game, if both of the players are playing optimally.
Optimal play between two players means that both players choose the best possible strategy to achieve the best possible outcome for themselves. In this problem, it means that each player, each time makes a move, which maximizes the final difference between his score and his opponent's score, knowing that the opponent is doing the same.
Input
The first line of input contains an integer n
(1≤n≤100000
) — the sizes of the list.
The second line contains n
integers ai (1≤ai≤106
), describing the list of the player A, who starts the game.
The third line contains n
integers bi (1≤bi≤106
), describing the list of the player B.
Output
Output the difference between A's score and B's score (A−B
) if both of them are playing optimally.
Examples
Input
Copy
2 1 4 5 1
Output
Copy
0
Input
Copy
3 100 100 100 100 100 100
Output
Copy
0
Input
Copy
2 2 1 5 6
Output
Copy
-3
Note
In the first example, the game could have gone as follows:
Hence, A's score is 1
, B's score is 1 and difference is 0
.
There is also another optimal way of playing:
The difference in the scores is still 0
.
In the second example, irrespective of the moves the players make, they will end up with the same number of numbers added to their score, so the difference will be 0
.题意:A和B两名玩家分别有一个长度为n的数组,游戏规则是,两人有一个初始得分是0,每次可以从自己的数组里取一个数字,作为自己的得分,也可以删掉对方数组中的一个数字,两人轮流进行,先A进行,保证玩家足够聪明,求AB两人得分差值的最大值
思路:每次比较自己的最大值是否大于对方的最大值,如果大于,则取自己的最大值作为自己的分数,如果小于则将对方的最大值删掉。
代码:
#include
#include
#include
using namespace std;
typedef long long LL;
const int N = 1e5+5;
int a[N],b[N];
int main(){
int n;
scanf("%d",&n);
for(int i=0;i=0&&a[i]>b[j]) ans1+=a[i--];
else j--;
if(j>=0&&b[j]>a[i]) ans2+=b[j--];
else i--;
}
printf("%lld\n",ans1-ans2);
return 0;
}