2020/9/07贝壳,买糖果那一题我一直为是0%,求查错

我的思路就是贪心算法,从第一天的价格开始,遍历下去,直到找到比这天价格低的,那么以那个价格为购买价格 购买这些天所需的糖果,以此反复,注意事项就是购买的糖果消耗后可能有剩余,下次购买时,购买数量要等于这段天数需求的数量减去前段剩余的。 还有就是最后到了边缘后还无最低价,则剩余糖果全按此价购买。
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)

#贝壳找房##笔试题目#
全部评论
有没有老哥帮忙看看,谢谢了
点赞 回复 分享
发布于 2020-09-07 17:46

相关推荐

10-09 22:05
666 C++
找到工作就狠狠玩CSGO:报联合国演讲,报电子烟设计与制造
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-20 19:57
已编辑
某大厂 golang工程师 23.0k*16.0, 2k房补,年终大概率能拿到
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务