Find Minimum Time
There are n processes to be executed, and the ith process has a size of processSize[i], where 1 ≤ i ≤ n. Also, there are m processors of different size capacity. The capacity of the ith processor is capacity[i] ( 1 ≤ i ≤ m ). A processor can process a task of size less than or equal to its capacity in 1 second, but it cannot execute processes whose size is greater than its capacity.
A processor can execute multiple processes one after the other, but needs to pause for 1 second after completing its current one. Multiple processors can work on different processes simultaneously.
Find the minimum time to execute all the processes or return -1 if there is no way to execute all the processes.
Complete the function findMinimumTime in the editor.
findMinimumTime has the following parameters:
- 1.
int[] processSize: an array of integers representing the sizes of processes - 2.
int[] capacity: an array of integers representing the capacities of processors
Returns
int: the minimum time to execute all the processes or -1 if it is not possible
1Example 1
The optimal way to assign processes is to give:
- The first processor the second process
- The second processor the first process
- The third processor the third process