You are given an integer n indicating there are n specialty retail stores. There are m product types of varying amounts, which are given as a 0-indexed integer array quantities, where quantities[i] represents the number of products of the ith product type.
You need to distribute all products to the retail stores following these rules:
A store can only be given at most one product type but can be given any amount of it.
After distribution, each store will have been given some number of products (possibly 0). Let x represent the maximum number of products given to any store. You want x to be as small as possible, i.e., you want to minimize the maximum number of products that are given to any store.
Input: n =6, quantities =[11,6]Output: 3Explanation: One optimal way is:- The 11 products of type 0 are distributed to the first four stores in these amounts:2,3,3,3- The 6 products of type 1 are distributed to the other two stores in these amounts:3,3The maximum number of products given to any store ismax(2,3,3,3,3,3)=3.
Example 2:
1
2
3
4
5
6
7
Input: n =7, quantities =[15,10,10]Output: 5Explanation: One optimal way is:- The 15 products of type 0 are distributed to the first three stores in these amounts:5,5,5- The 10 products of type 1 are distributed to the next two stores in these amounts:5,5- The 10 products of type 2 are distributed to the last two stores in these amounts:5,5The maximum number of products given to any store ismax(5,5,5,5,5,5,5)=5.
Example 3:
1
2
3
4
5
Input: n =1, quantities =[100000]Output: 100000Explanation: The only optimal way is:- The 100000 products of type 0 are distributed to the only store.The maximum number of products given to any store ismax(100000)=100000.
We need to distribute products to n stores such that the maximum number of products any store receives, x, is minimized. Here’s how we can approach this problem:
Binary Search: We’ll use binary search to minimize x. The range of x is between 1 (if each store gets at least one product) and the maximum possible value in quantities (in case all products of one type go to one store).
Feasibility Check: For a given x during the binary search, we need to check if it’s feasible to distribute the products such that no store gets more than x products. We can sum the number of stores needed for each product type to ensure it doesn’t exceed n.
⏰ Time complexity: O(m log(max(quantities))) where m is the number of product types. This accounts for the binary search over the range and validating each guess which involves a single pass through quantities.
🧺 Space complexity: O(1) since we’re only using a few additional variables.