Rod Cutting - Dynamic Programming
Rod cutting problem uses dynamic programming to solve a problem in deciding where to cut steel rods.
Problem:
Given a rod of length n inches and an array of prices pi for i = 1,2,…n that includes prices of all pieces of size smaller than n. Determine the maximum revenue value rn obtainable by cutting up the rod and selling the pieces. Note that if piece pn for a rod of length n is large enough, an optimal solution may equire no cutting at all.
Recursive Approach
In this approach, we decompose the rod. The decomposition consists of the first piece of length i cut of the left hand end, and then the right-hand remainder of length n - i. Only the remainder from the right side can be decomposed further.
For large values of n, this approach would be extremly slow due to many redundant operations.
Dynammic Programming Approach
How do we meet the necessary properties for dynamic programming?
- Optimal Structure - We can cut the rod in different spots and compare the prices after each cut. Then we can recursively call the same function on a piece obtained after the cut.
- Overlapping Subproblems - In our recursive implementation, we can see that many subproblems are repeating/overlapping.
Top-Down Dynamic Programming Approach
As we know, this method is similar to the original recursive method, but it includes memoization, the process of saving/cashing/remembering already computed values.
Bottom-up Dynamic Programming Approach
In the following piece of code, the for loop with j variable represents the length of the rod we plan on cutting. In order to get the best possible price, we must first iterate through all possible smaller sizes of the rod and calculate their maximum prices in order to get the best possible price for the rod of size n.
In the for loop with i variable, we will find the maximum price for the rod of size j by cutting this piece of rod at index i. Compare the maximum_value found so far (starts from negative infiniti) with the price of the cut at next index. At the end of the loop, the maximum value will be compared with the given price for the whole rod without cutting since j-i will be equal to 0 in the last iteration of the loop which will result in prices[i] only (left side of the cut).
Running time of this approach is &theta(n^2) due to its nesed for loop.
Now, this solution only gives us the maximum price that we can get for slicing or not slicing the rod of length n. We can modify our function to give us a full solution that consists of not only the maximum price, but also the position where the rod needs to be cut in order to get the maximum value/revenue for the rod of length n.
Let us see how this would work on an example. We are give the following lists:
After running our last function cut_rod_plus(prices, n)
, we get results such as:
Here we can see that if we had a rod of length 5, we would need to cut the rod at index 2, which leaves us with left side of the rod with length 2 and the right side of length 3. When prices of those 2 sides are combined, the value is 13 (greater than 10, or any other combination), which is the maximum value it could be gotten for selling the rod of length 5.
The Squid