https://yesterz.github.io/posts/Dynamic-Programming-ii/
Lecture-5 Dynamic Programming II - All too well