Fair Candy Swap
Problem
Alice and Bob have a different total number of candies. You are given two integer arrays aliceSizes
and bobSizes
where aliceSizes[i]
is the number of candies of the ith
box of candy that Alice has and bobSizes[j]
is the number of candies of the jth
box of candy that Bob has.
Since they are friends, they would like to exchange one candy box each so that after the exchange, they both have the same total amount of candy. The total amount of candy a person has is the sum of the number of candies in each box they have.
Return an integer array answer
where answer[0]
is the number of candies in the box that Alice must exchange, and answer[1]
is the number of candies in the box that Bob must exchange. If there are multiple answers, you may return any one of them. It is guaranteed that at least one answer exists.
Constraints
1 <= aliceSizes.length, bobSizes.length <= 104
1 <= aliceSizes[i], bobSizes[j] <= 105
- Alice and Bob have a different total number of candies.
- There will be at least one valid answer for the given input.
Solution
The problem Fair Candy Swap
can be solved by finding the difference in total number of candies for Alice and Bob. If the total number of candies for Alice changes by N
after the exchange of a box, then the total number of candies for Bob will change by -N
. Therefore, in order to make the total amount of candy equal, we need to find two boxes which changes Alice’s total number of candies by 2N = S
where S
is the difference in total number of candies for Alice and Bob.
Implementation
static const int fast_io = []()
{
std::ios::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
return 0;
}();
class Solution
{
public:
vector<int> fairCandySwap(vector<int> &aliceSizes, vector<int> &bobSizes)
{
int offset = accumulate(bobSizes.begin(), bobSizes.end(), 0);
offset -= accumulate(aliceSizes.begin(), aliceSizes.end(), 0);
offset /= 2;
bitset<100001> hashset;
for (int &candies : aliceSizes)
if (1 <= candies + offset && candies + offset <= 100000)
hashset.set(candies + offset);
vector<int> ret;
for (int &candies : bobSizes)
if (hashset.test(candies))
{
ret.push_back(candies - offset);
ret.push_back(candies);
break;
}
return ret;
}
};