enter KNAPSACK. a common cs problem that seems very similar. a brief translation to this problem would be: given my possessions (the items,) and the UHaul truck (my knapsack,) maximize the amount of stuff i can cram into the truck.
however this variation has a few curveballs:
- in KNAPSACK, items are usually just real numbers, here they are objects with a volume.
- this means that you could have a subset whose overall size is the largest w/o surpassing the volume of the truck, but you are now confronted with the task of actually finding an orientation of the items in container that actually fits everything.
- not only do you have volume, but i think shape might be a pretty weird variable in the item set.
- you realistically want to value/prioritize which items you must include like your bed or dresser or tv.
- at a certain point, if not all possessions can be fit in the container at the same time, the problem shifts from maximizing usage to minimizing the number of containers needed to consume all items.
- you normally are doing things in a pipeline manner, (sorting, packing into boxes, moving boxes into truck.) so you might not have the omniscient view of all items as you start to pack the truck, and ymmv based on when you see certain items. this throws the traditional dynamic programming approach out the window.
- confine all items to be rectangular prisms
- maybe even start with 2D (packing rectangles,) which i want to dub PLANTING for maximizing crop sections in the fields.