We are given two strings, called the source and the target, which both have the same number of characters n. The goal is to transform the target string into the source string using the smallest number of allowed operations. There are two types of allowed operations, a flip and a substitution.
We should assume that the portions where any two flips are applied don't overlap. That is, if we perform flip(i,j) and flip(k,l), then the sets {i,i+1,...,j} and {k,k+1,...,l} are disjoint.
Consider the source string timeflieslikeanarrow and the target string tfemiliilzejeworrbna. The following sequence transforms the target into the source:
The number of operations used, which is the quantity we seek to minimize, was 6. Note that we never need more operations than the length of the given strings.
Write a time-efficient program that takes as input a file containing the two input strings and prints out the optimal sequence of transformations from the target to the source. You can assume that the file is formatted like this example. Each string will be a sequence of lower-case English characters. Note that for the grading we plan to measure time-efficiency by actual running time on strings of length up to five hundred or even a thousand. As background reading for designing your algorithm, it may help to study the dynamic programming approach to compute the edit distance between two strings.
Your submission for this homework should consist of two files: (a) your source code (b) a document with some text describing your algorithm and instructions on how to compile and/or run your program with a given input file.