All Downloads are FREE. Search and download functionalities are using the official Maven repository.

g0801_0900.s0888_fair_candy_swap.Solution Maven / Gradle / Ivy

There is a newer version: 1.38
Show newest version
package g0801_0900.s0888_fair_candy_swap;

// #Easy #Array #Hash_Table #Sorting #Binary_Search
// #2022_03_28_Time_18_ms_(68.20%)_Space_72.2_MB_(19.02%)

import java.util.HashSet;

/**
 * 888 - Fair Candy Swap\.
 *
 * Easy
 *
 * 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 a_n 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.
 *
 * **Example 1:**
 *
 * **Input:** aliceSizes = [1,1], bobSizes = [2,2]
 *
 * **Output:** [1,2]
 *
 * **Example 2:**
 *
 * **Input:** aliceSizes = [1,2], bobSizes = [2,3]
 *
 * **Output:** [1,2]
 *
 * **Example 3:**
 *
 * **Input:** aliceSizes = [2], bobSizes = [1,3]
 *
 * **Output:** [2,3]
 *
 * **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.
**/
public class Solution {
    public int[] fairCandySwap(int[] aliceSizes, int[] bobSizes) {
        int aSum = 0;
        int bSum = 0;
        int diff;
        int[] ans = new int[2];
        for (int bar : aliceSizes) {
            aSum += bar;
        }
        for (int bar : bobSizes) {
            bSum += bar;
        }
        diff = aSum - bSum;
        HashSet set = new HashSet<>();
        for (int bar : aliceSizes) {
            set.add(bar);
        }
        for (int bar : bobSizes) {
            if (set.contains(bar + diff / 2)) {
                ans[0] = bar + diff / 2;
                ans[1] = bar;
                break;
            }
        }
        return ans;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy