Your task is to implement the Rod Cutting algorithm (a classic Dynamic Programming problem from CLRS) and verify its correctness in Dafny. You are given a rod of length n and a table of prices where the $i$-th element represents the price of a rod piece of length $i+1$. The goal is to determine the maximum revenue obtainable by cutting up the rod and selling the pieces.In the incomplete code, the specification defines what constitutes a valid cut strategy (a list of piece lengths that sum up to n) and how to calculate the total revenue of a strategy. Your task is to implement the algorithm and verify that it returns the optimal revenue. Specifically, you must prove: (1) Upper Bound: Any valid set of cuts yields a total revenue less than or equal to the returned result. (2) Existence: There exists a valid set of cuts whose total revenue is exactly equal to the returned result.
