2974. Minimum Number Game

shashi
3 min readMar 23, 2024

--

Solved

Easy

Topics

Companies

Hint

You are given a 0-indexed integer array nums of even length and there is also an empty array arr. Alice and Bob decided to play a game where in every round Alice and Bob will do one move. The rules of the game are as follows:

  • Every round, first Alice will remove the minimum element from nums, and then Bob does the same.
  • Now, first Bob will append the removed element in the array arr, and then Alice does the same.
  • The game continues until nums becomes empty.

Return the resulting array arr.

Example 1:

Input: nums = [5,4,2,3]
Output: [3,2,5,4]
Explanation: In round one, first Alice removes 2 and then Bob removes 3. Then in arr firstly Bob appends 3 and then Alice appends 2. So arr = [3,2].
At the begining of round two, nums = [5,4]. Now, first Alice removes 4 and then Bob removes 5. Then both append in arr which becomes [3,2,5,4].

Example 2:

Input: nums = [2,5]
Output: [5,2]
Explanation: In round one, first Alice removes 2 and then Bob removes 5. Then in arr firstly Bob appends and then Alice appends. So arr = [5,2].

Constraints:

  • 1 <= nums.length <= 100
  • 1 <= nums[i] <= 100
  • nums.length % 2 == 0
class Solution {
public int[] numberGame(int[] nums) {
int n=nums.length;
// Arrays.sort(nums);
// quickSort(nums,0,n-1);
mergeSort(nums,0,n-1);
System.out.println(Arrays.toString(nums));
int[] ans=new int[n];

int j=0;
for(int i=0;i<n;i+=2){
ans[j++]=nums[i+1];
ans[j++]=nums[i];
}
return ans;
}

/** Time : O(nlog(n)) , O(n^2) Space : O(1) */
public void quickSort(int[] nums,int l,int r){
if(l<r) {
int pi=partition(nums,l,r);
quickSort(nums,l,pi-1);
quickSort(nums,pi+1,r);
}
}

public int partition(int[] nums,int l,int r){
int i=l-1,j=l;
while(j<r){
if(nums[r]>nums[j]) swap(nums,++i,j);
j++;
}
swap(nums,++i,r);
return i;

}

public void swap(int[] nums,int i, int j){
int temp=nums[i];
nums[i]=nums[j];
nums[j]=temp;
}

/**Time : O(nlog(n)) Space :O(n) */
public void mergeSort(int[] nums, int l , int r){
if(l<r){
int m=l +(r-l)/2;
mergeSort(nums,l,m);
mergeSort(nums,m+1,r);
merge(nums,l,m,r);
}
}
public void merge(int[] nums,int l,int mid, int r){
int n=mid-l+1,m=r-mid,i=0,j=0,k=0;
int[] nArr=new int[n], mArr=new int[m];

while(i<n) nArr[i]=nums[l + i++];
while(j<m) mArr[j]=nums[mid+1 + j++];

i=0;j=0;k=l;
while(i<n && j<m) nums[k++]= nArr[i]<=mArr[j] ? nArr[i++] :mArr[j++];

while(i<n) nums[k++]=nArr[i++];
while(j<m) nums[k++]=mArr[j++];
}
}

/**
2974. Minimum Number Game
Solved
Easy
Topics
Companies
Hint
You are given a 0-indexed integer array nums of even length and there is also an empty array arr. Alice and Bob decided to play a game where in every round Alice and Bob will do one move. The rules of the game are as follows:

Every round, first Alice will remove the minimum element from nums, and then Bob does the same.
Now, first Bob will append the removed element in the array arr, and then Alice does the same.
The game continues until nums becomes empty.
Return the resulting array arr.



Example 1:

Input: nums = [5,4,2,3]
Output: [3,2,5,4]
Explanation: In round one, first Alice removes 2 and then Bob removes 3. Then in arr firstly Bob appends 3 and then Alice appends 2. So arr = [3,2].
At the begining of round two, nums = [5,4]. Now, first Alice removes 4 and then Bob removes 5. Then both append in arr which becomes [3,2,5,4].
Example 2:

Input: nums = [2,5]
Output: [5,2]
Explanation: In round one, first Alice removes 2 and then Bob removes 5. Then in arr firstly Bob appends and then Alice appends. So arr = [5,2].

Constraints:

1 <= nums.length <= 100
1 <= nums[i] <= 100
nums.length % 2 == 0


*/

--

--

shashi
shashi

No responses yet