https://medium.com/better-programming/the-technical-interview-guide-to-dynamic-programming-3ce755d99849