tr = [None, {'w': 2, 'v': 3}, {'w': 3, 'v': 4},
{'w': 4, 'v': 8}, {'w': 5, 'v': 8},
{'w': 9, 'v': 10}]
max_w = 20
m = {(i, w): 0 for i in range(len(tr))
for w in range(max_w + 1)}
print(m)
for i in range(1, len(tr)):
for w in range(1, max_w + 1):
if tr[i]['w'] > w:
m[(i, w)] = m[(i - 1, w)]
else:
m[(i, w)] = max(
m[(i - 1, w)],
m[(i - 1, w - tr[i]['w'])] + tr[i]['v'])
print('m1', m)
print(m[(len(tr) - 1, max_w)])
【dp练习】博物馆大道问题
最新推荐文章于 2022-04-04 16:16:39 发布