019f8fd211
git-subtree-dir: users/wpcarro git-subtree-mainline:464bbcb15c
git-subtree-split:24f5a642af
Change-Id: I6105b3762b79126b3488359c95978cadb3efa789
50 lines
1.1 KiB
Python
50 lines
1.1 KiB
Python
from random import randint
|
|
|
|
class Box(object):
|
|
def __init__(self, w, h, d):
|
|
self.width = w
|
|
self.depth = d
|
|
self.height = h
|
|
|
|
def __repr__(self):
|
|
return "{}x{}x{}".format(self.width, self.depth, self.height)
|
|
|
|
def lt(self, b):
|
|
return all([
|
|
self.width < b.width,
|
|
self.height < b.height,
|
|
self.depth < b.depth,
|
|
])
|
|
|
|
def gt(self, b):
|
|
return all([
|
|
self.width > b.width,
|
|
self.height > b.height,
|
|
self.depth > b.depth,
|
|
])
|
|
|
|
def random_box():
|
|
return Box(
|
|
randint(1, 10),
|
|
randint(1, 10),
|
|
randint(1, 10),
|
|
)
|
|
|
|
xs = [random_box() for _ in range(5)]
|
|
|
|
def highest_stack(xs, cache={}):
|
|
if not xs:
|
|
return 0
|
|
heights = []
|
|
for i in range(len(xs)):
|
|
x, rest = xs[i], xs[0:i] + xs[i+1:]
|
|
if cache and x in cache:
|
|
height = cache[x]
|
|
else:
|
|
height = x.height + highest_stack([b for b in rest if x.gt(b)], cache)
|
|
cache[x] = height
|
|
heights += [height]
|
|
return max(heights)
|
|
|
|
print(xs)
|
|
print(highest_stack(xs))
|