我的思路就是贪心算法,从第一天的价格开始,遍历下去,直到找到比这天价格低的,那么以那个价格为购买价格 购买这些天所需的糖果,以此反复,注意事项就是购买的糖果消耗后可能有剩余,下次购买时,购买数量要等于这段天数需求的数量减去前段剩余的。 还有就是最后到了边缘后还无最低价,则剩余糖果全按此价购买。
n,m = map(int,input().split())
a = list(map(int,input().split()))
p = list(map(int,input().split()))
i = 0
j = 0
min_p = 1001
remain_candy = 0
sum_money = 0
while i<len(p):
if p[i]<min_p:
min_p = p[i]
sum_a_day = (sum(a[j:i])-remain_candy+1)//m
sum_money += sum_a_day * p[i-1]
remain_candy = sum_a_day * m - sum(a[j:i])
j = i
i = i+1
else:
i += 1
if i==len(p):
sum_a_day = (sum(a[j:])-remain_candy+1)//m
sum_money += sum_a_day * p[j]
break
print(sum_money)
全部评论
(1) 回帖