Skip to content

3494. Find the Minimum Amount of Time to Brew Potions

Description

You are given two integer arrays, skill and , of length n and m, respectively.

In a laboratory, n wizards must brew m potions in order. Each potion has a mana capacity mana[j] and must pass through all the wizards sequentially to be brewed properly. The time taken by the ith wizard on the jth potion is timeij = skill[i] * mana[j].

Since the brewing process is delicate, a potion must be passed to the next wizard immediately after the current wizard completes their work. This means the timing must be synchronized so that each wizard begins working on a potion exactly when it arrives. ​

Return the minimum amount of time required for the potions to be brewed properly.

 

Example 1:

Input: skill = [1,5,2,4], mana = [5,1,4,2]

Output: 110

Explanation:

Potion NumberStart timeWizard 0 done byWizard 1 done byWizard 2 done byWizard 3 done by
005304060
15253586064
254587886102
3868898102110

As an example for why wizard 0 cannot start working on the 1st potion before time t = 52, consider the case where the wizards started preparing the 1st potion at time t = 50. At time t = 58, wizard 2 is done with the 1st potion, but wizard 3 will still be working on the 0th potion till time t = 60.

Example 2:

Input: skill = [1,1,1], mana = [1,1,1]

Output: 5

Explanation:

  1. Preparation of the 0th potion begins at time t = 0, and is completed by time t = 3.
  2. Preparation of the 1st potion begins at time t = 1, and is completed by time t = 4.
  3. Preparation of the 2nd potion begins at time t = 2, and is completed by time t = 5.

Example 3:

Input: skill = [1,2,3,4], mana = [1,2]

Output: 21

 

Constraints:

  • n == skill.length
  • m == mana.length
  • 1 <= n, m <= 5000
  • 1 <= mana[i], skill[i] <= 5000

 

Solutions

Solution: Prefix Sum

  • Time complexity: O(mn)
  • Space complexity: O(1)

 

JavaScript

js
/**
 * @param {number[]} skill
 * @param {number[]} mana
 * @return {number}
 */
const minTime = function (skill, mana) {
  const n = skill.length;
  const m = mana.length;
  const sumSkill = skill.reduce((result, s) => result + s);
  let prevWizardDone = sumSkill * mana[0];

  for (let index = 1; index < m; index++) {
    let prevPotionDone = prevWizardDone;

    for (let wizard = n - 2; wizard >= 0; wizard--) {
      const time = skill[wizard] * mana[index];

      prevPotionDone -= skill[wizard + 1] * mana[index - 1];
      prevWizardDone = Math.max(prevPotionDone, prevWizardDone - time);
    }

    prevWizardDone += sumSkill * mana[index];
  }

  return prevWizardDone;
};

Released under the MIT license