Solution

dynamic programming with slope optimization & monotonous queue
Algorithms    Solution / HNOI / DP
dynamic programming with monotonous stack
using the idea called "Meet in The Middle"