Search code examples
algorithmdynamic-programmingsequence-alignment

Stacking boxes algorithm


enter image description here

I'm a little stuck trying to solve this problem. The main source of confusion comes from not knowing when to remove a box.

Here's my approach:

I look at the container column by column. If the top most box of the origin box is empty and the destination box is not empty, then i know to add that box. And i know to remove the top box if its vice versa. I think that I have to swap when both positions have a box but are different. However my problem comes with certain cases where removing a box at the bottom will shift everything down and make it more like the destination box. Or maybe removing one in the center or removing two, one in the bottom and one in the center. How do I know when to remove a box? I can remove all combinations and see which makes it most close to the destination but that doesn't seem efficient.

I also maybe think that this is an obvious dynamic programming problem thats going over my head. Any help would be appreciated


Solution

  • You have already reduced the problem to considering one column at a time, so let us start with that.

    Instead of considering particular operations that can happen in a column, let us look at the process in general. Initially, we have the given column. At the end, we have the resulting column. What's left of the given column in the resulting column? It is a subsequence (since we can remove a box from anywhere) of the given column which transferred to a prefix of the resulting column ("prefix" as in "located at the bottom", since we can add new boxes only on top of what was there initially).

    Naturally, we want to maximize the length of this sequence (subsequence or prefix, depending on where you look at). That sure looks like a dynamic programming problem, similar to edit distance or longest common subsequence. Perhaps you will want to work out the details yourself from this point. Good luck!