Find Largest Average of Sublist with Minimum Size k in Python



Suppose we have a list of numbers called nums and another value k, we have to find the largest average value of any sublist of the list whose length is at least k.

So, if the input is like nums = [2, 10, -50, 4, 6, 6] k = 3, then the output will be 5.33333333, as sublist [4, 6, 6] has the largest average value

To solve this, we will follow these steps −

  • left := minimum of nums, right := maximum of nums

  • s := sum of all numbers in nums from index 0 to k − 1

  • largest_avg := s / k

  • while left <= right, do

    • mid :=integer of (left + right) / 2

    • sum1 := s, avg := s / k, sum2 := 0, cnt := 0

    • for i in range k to size of nums, do

      • sum1 := sum1 + nums[i]

      • sum2 := sum2 + nums[i − k]

      • cnt := cnt + 1

      • avg := maximum of avg and (sum1 /(cnt + k))

      • if sum2 / cnt <= mid, then

        • sum1 := sum1 − sum2

        • cnt := 0, sum2 := 0

      • avg := maximum of avg and (sum1 /(cnt + k))

    • largest_avg := maximum of largest_avg and avg

    • if avg > mid, then

      • left := mid + 1

    • otherwise,

      • right := mid − 1

  • return largest_avg

Let us see the following implementation to get better understanding −

Example

 Live Demo

class Solution:
   def solve(self, nums, k):
      left, right = min(nums), max(nums)
      s = sum(nums[:k])
      largest_avg = s / k
      while left <= right:
         mid = (left + right) // 2
         sum1 = s
         avg = s / k
         sum2 = 0
         cnt = 0
         for i in range(k, len(nums)):
            sum1 += nums[i]
            sum2 += nums[i − k]
            cnt += 1
            avg = max(avg, sum1 / (cnt + k))
            if sum2 / cnt <= mid:
               sum1 −= sum2
               cnt = 0
               sum2 = 0
            avg = max(avg, sum1 / (cnt + k))
         largest_avg = max(largest_avg, avg)
         if avg > mid:
            left = mid + 1
         else:
            right = mid − 1
      return largest_avg
ob = Solution()
nums = [2, 10, −50, 4, 6, 6]
k = 3
print(ob.solve(nums, k))

Input

[2, 10, −50, 4, 6, 6], k = 3

Output

5.333333333333333
Updated on: 2020-12-26T10:59:53+05:30

277 Views

Kickstart Your Career

Get certified by completing the course

Get Started
Advertisements