在 Python 中查找最接近的甜点成本的程序
假设我们有两个名为baseCosts的数组,其中有n个项目,我们可以从中选择base和toppingCosts,其中有m个项目,我们可以选择toppings并有一个目标值。我们必须遵循这些规则来制作甜点。
必须正好有一个基地。
我们可以添加一种或多种配料,也可以完全不添加配料。
每种类型的浇头最多有两种。
这里baseCosts[i]代表第i个冰淇淋基料的价格。TopingCosts[i]表示第i个浇头之一的价格。目标值代表甜点的目标价格。我们必须制作一个总成本尽可能接近目标的甜点。我们必须找到最接近的甜点成本作为目标。如果有多个答案,返回较低的一个。
因此,如果输入类似于baseCosts=[2,8],toppingCosts=[4,5],target=12,那么输出将为12,因为我们可以以成本8取基数,然后以成本取第一个顶部的14,而且没有type2浇头,所以总成本8+4=12。
示例
让我们看看以下实现以获得更好的理解-
def solve(baseCosts, toppingCosts, target):
best_cost = baseCosts[0]
for b in range(len(baseCosts)):
bitmask = [0] * len(toppingCosts)
while True:
current_price = baseCosts[b]
for j in range(len(bitmask)):
current_price += bitmask[j] * toppingCosts[j]
if current_price - target == 0:
return target
elif abs(current_price - target) < abs(best_cost - target):
best_cost = current_price
elif abs(current_price - target) == abs(best_cost - target):
if current_price < best_cost:
best_cost = current_price
if 0 not in bitmask and 1 not in bitmask:
break
for i in range(len(bitmask)):
if bitmask[i] != 2:
bitmask[i] += 1
break
else:
bitmask[i] = 0
return best_cost
baseCosts = [2,8]
toppingCosts = [4,5]
target = 12
print(solve(baseCosts, toppingCosts, target))输入
[2,8], [4,5], 12输出结果
12