-
-
Notifications
You must be signed in to change notification settings - Fork 155
added solution of leetcode problem 888 #1978
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from 1 commit
Commits
Show all changes
5 commits
Select commit
Hold shift + click to select a range
6dae190
Create 0888- Fair-Candy-Swap.md
aditya-bhaumik 8460410
Merge branch 'main' into 888
ajay-dhangar 5fc502d
Merge branch 'main' into 888
ajay-dhangar a65b988
Update 0888- Fair-Candy-Swap.md
aditya-bhaumik b541766
Merge branch 'main' into 888
ajay-dhangar File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
73 changes: 73 additions & 0 deletions
73
dsa-solutions/lc-solutions/0800- 0899/0888- Fair-Candy-Swap.md
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
--- | ||
id: fair-candy swap | ||
title: Fair Candy Swap | ||
sidebar_label: 888- Fair Candy Swap | ||
tags: | ||
- Array | ||
- Hash Table | ||
- Sorting | ||
description: Find one pair of candy boxes, one from Alice and one from Bob, to swap so they both end up with the same total number of candies. | ||
sidebar_position: 0888 | ||
--- | ||
|
||
## Problem Description | ||
|
||
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. | ||
|
||
### Example 1 | ||
|
||
- **Input:** `aliceSizes = [1,1], bobSizes = [2,2]` | ||
- **Output:** `[1,2]` | ||
|
||
|
||
### Constraints | ||
|
||
- `1 <= aliceSizes.length, bobSizes.length <= 104` | ||
- `1 <= aliceSizes[i], bobSizes[j] <= 105` | ||
|
||
## Approach | ||
|
||
The solution first calculates the total number of candies each Alice and Bob have. Then, it sorts Bob's candy boxes for efficient searching. It iterates over Alice's candy boxes, checking if swapping a box with Bob can balance their total candies. For each box of Alice, it calculates the required box from Bob and uses binary search to find it in Bob's sorted array. If a valid swap is found, it updates the answer and returns it. | ||
|
||
#### Java | ||
```Java | ||
class Solution { | ||
public int[] fairCandySwap(int[] aliceSizes, int[] bobSizes) { | ||
Arrays.sort(bobSizes); | ||
int aliceSum=0; | ||
int bobSum=0; | ||
for(int i=0;i<aliceSizes.length;i++){ | ||
aliceSum+=aliceSizes[i]; | ||
} | ||
for(int i=0;i<bobSizes.length;i++){ | ||
bobSum+=bobSizes[i]; | ||
} | ||
int [] ans=new int [2]; | ||
|
||
for(int i=0;i<aliceSizes.length;i++){ | ||
if((bobSum-aliceSum+(2*aliceSizes[i]))%2!=0){ | ||
break; | ||
} | ||
if(Arrays.binarySearch(bobSizes,(bobSum-aliceSum+(2*aliceSizes[i]))/2)>=0){ | ||
ans[0]=aliceSizes[i]; | ||
ans[1]=(bobSum-aliceSum+(2*aliceSizes[i]))/2; | ||
} | ||
else if(aliceSizes[i]==(bobSum-aliceSum+(2*aliceSizes[i]))/2){ | ||
ans[0]=aliceSizes[i]; | ||
ans[1]=aliceSizes[i]; | ||
} | ||
} | ||
return ans; | ||
} | ||
} | ||
``` | ||
|
||
- Time Complexity | ||
The time complexity is o(n). | ||
ajay-dhangar marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
- Space Complexity | ||
The space complexity is O(1). | ||
aditya-bhaumik marked this conversation as resolved.
Show resolved
Hide resolved
|
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.