Intuition
A brute force approach to this is to test every possible capacity and track the lowest one.
We can optimize this by having a search space of all possible capacities and then reducing the capacities in half at every iteration so it the complexity of searching drops down to O(log N)
.
But when we do this, for every capacity that we are guessing, we would require to iterate over the entire array to see if this new
capacity works.
We have a load_ship
function that takes in a possible capacity and simulates the process of loading the ship - if it’s works we look in the left search space to see if we can go any smaller. Else if our capacity is to small to load the ship, we look into the right space - implying that we are increasing our capacity.
To understand this better, read more about Binary Search
More problems like this
1482 Minimum Number of Days to Make m Bouquets
Code
Python3
Big O Analysis
-
Runtime
The runtime complexity here is since we are reducing our search space of size K in half (capacities) but for every capacity that we test - we also iterate the entire array of size N.
-
Memory
The memory usage is since we are not using any extra data structure.
— A