Max Min Discussions | Algorithms | HackerRank

Sort by

recency

|

881 Discussions

|

  • + 0 comments

    JS

    function maxMin(k, arr) {
      // sort - lowest to highest
      arr.sort((a, b) => a - b);
    
      // calculate unfairness of "first chunk" of size k
      let minUnfairness = arr[k - 1] - arr[0];
    
      for (let i = 1; i + k - 1 < arr.length; i++) {
        // calculate unfairness in "next chunk" of size k
        const unfairness = arr[i + k - 1] - arr[i];
    
        if (unfairness < minUnfairness) {
          minUnfairness = unfairness;
        }
      }
    
      return minUnfairness;
    }
    
  • + 0 comments

    Java Solution

    Collections.sort(arr);
    int min=Integer.MAX_VALUE;
    for(int i=0;i<arr.size()-k+1;i++){
        if((arr.get(i+k-1)-arr.get(i))<min)
        {
            min=arr.get(i+k-1)-arr.get(i);
        }
    }
    return min;
    
    }
    
  • + 0 comments

    Two pointer approach

    def maxMin(k, arr):
        # Write your code here
        arr.sort()
        unfairness = []
        p1 = 0
        p2 = k - 1
        
        while p2 < len(arr):
            unfairness.append(arr[p2] - arr[p1])
            p1 += 1
            p2 += 1
        return min(unfairness)
        ****
    
  • + 0 comments
    def maxMin(k, arr):
        # Write your code here
        n = len(arr)
        arr.sort()
        res=[]
        for i in range(n-k+1):
            uf=arr[i+k-1] - arr[i]
            print(uf)
            res.append(uf)
        return min(res)
    
  • + 0 comments

    `java public static int maxMin(int k, List arr) { // Write your code here // Sorting and Sliding Window Collections.sort(arr); int min = 0; int end = 0; int start = 0; int minUnfairness = Integer.MAX_VALUE; while(end < arr.size()) { if((end-start)+1 < k) { end++; }else { int currentUnfairness = arr.get(end) - arr.get(start); minUnfairness = Math.min(minUnfairness, currentUnfairness); start++; } } return minUnfairness; }

    `