You are given a 0-indexed integer array nums whose length is a power of 2.
Apply the following algorithm on nums:
- Let nbe the length ofnums. Ifn == 1, end the process. Otherwise, create a new 0-indexed integer arraynewNumsof lengthn / 2.
- For every even index iwhere0 <= i < n / 2, assign the value ofnewNums[i]asmin(nums[2 * i], nums[2 * i + 1]).
- For every odd index iwhere0 <= i < n / 2, assign the value ofnewNums[i]asmax(nums[2 * i], nums[2 * i + 1]).
- Replace the array numswithnewNums.
- Repeat the entire process starting from step 1.
Return the last number that remains in nums after applying the algorithm.
Example 1:
![[Solution] Min Max Game - LeetCode Weekly Contest 296 [Solution] Min Max Game - LeetCode Weekly Contest 296](https://assets.leetcode.com/uploads/2022/04/13/example1drawio-1.png)
Input: nums = [1,3,5,2,4,8,2,2] Output: 1 Explanation: The following arrays are the results of applying the algorithm repeatedly. First: nums = [1,5,4,2] Second: nums = [1,4] Third: nums = [1] 1 is the last remaining number, so we return 1.
Example 2:
Input: nums = [3] Output: 3 Explanation: 3 is already the last remaining number, so we return 3.
Constraints:
- 1 <= nums.length <= 1024
- 1 <= nums[i] <= 109
- nums.lengthis a power of- 2.
Solution:
Space Complexity: O(1)
class Solution {
public:
    int minMaxGame(vector<int>& nums) {
        
        int n(size(nums));
        for (; n>1; n-=n/2) {
            for (int i=0; i<n/2; i++) {
                nums[i] = ((i % 2 == 1) ? max(nums[2*i], nums[2*i+1]) : min(nums[2*i], nums[2*i+1]));
            }
        }
        return nums[0];
    }
};Space Complexity: O(n)
class Solution {
public:
    int minMaxGame(vector<int>& nums) {
        
        while (size(nums) != 1) {
            
            vector<int> temp;
            for (int i=0; i<size(nums)/2; i++) {
                temp.push_back((i % 2 == 1) ? max(nums[2*i], nums[2*i+1]) : min(nums[2*i], nums[2*i+1]));
            }
            nums = temp;
        }
        return nums[0];
    }
};class Solution {
    public int minMaxGame(int[] a) {
    for(int n= a.length; n>1 ; n-=(n/2)){
        for(int i=0;i<n/2;i++) 
		    a[i]= (i%2)==1? Math.max(a[2 * i], a[2 * i + 1]) : Math.min(a[2 * i], a[2 * i + 1]);   
    }
    return a[0];
}
}Time Complexity: O(n)
– No need to create new array.
– It can be seen that changes can be mae within same array.
– The changed elements are never called again so their positions are useless and we use those vacant indexes.
class Solution:
    def minMaxGame(self, a: List[int]) -> int:
        
        def solve(n):
            if n==1:
                return
            for i in range(n//2):
                if i%2:
                    a[i] = max (a[2*i], a[2*i+1])
                else:
                    a[i] = min (a[2*i], a[2*i+1])
            solve(n//2)
            return
        solve(len(a))
        return a[0]Happy Learning – If you require any further information, feel free to contact me.
![[Solution] Min Max Game - LeetCode Weekly Contest 296 Min Max Game - LeetCode Weekly Contest 296](https://realcoder.techss24.com/wp-content/uploads/2022/06/Min-Max-Game-LeetCode-Weekly-Contest-296.png)
![[Solved] The Latest Time to Catch a Bus LeetCode Contest](https://realcoder.techss24.com/wp-content/uploads/2022/07/Solved-The-Latest-Time-to-Catch-a-Bus-LeetCode-Contest-300x200.png)
![[Solved] Planting Trees](https://realcoder.techss24.com/wp-content/uploads/2022/11/Solved-Planting-Trees-300x198.png)
![[Solved] To the Magic Show with Java, C++](https://realcoder.techss24.com/wp-content/uploads/2022/07/Solved-To-the-Magic-Show-with-Java-C-300x200.png)