Convex hull trick
Not to be confused with convex hull, the convex hull trick is a dynamic programming optimization technique. It can be thought of as a data structure supporting the following operations:
- Insert(ax+b): insert the line
into the data structure - GetMin(x): considering all the lines that have been inserted so far, return the one that has the minimum value at
Applicability
The convex hull trick applies when the dynamic programming recurrence is approximately of the form
TODO: Talk about dynamic vs. static variants
Sometimes the above form appears within a more complex recurrence, as is the case for
Problems
- Commando
- Land Acquisition
- Batch Scheduling
- Covered Walkway
- Branch Assignment
- Good Inflation
- Cats Transport1
- Cow School2
- Kalila and Dimna in the Logging Industry3
- Leaves
- Squared Ends