力扣刷题笔记:5638. 吃苹果的最大数目(堆,算法搬运,这题还挺难的。。。)

题目:

5638.吃苹果的最大数目
有一棵特殊的苹果树,一连 n 天,每天都可以长出若干个苹果。在第 i 天,树上会长出 apples[i] 个苹果,这些苹果将会在 days[i] 天后(也就是说,第 i + days[i] 天时)腐烂,变得无法食用。也可能有那么几天,树上不会长出新的苹果,此时用 apples[i] == 0 且 days[i] == 0 表示。

你打算每天 最多 吃一个苹果来保证营养均衡。注意,你可以在这 n 天之后继续吃苹果。

给你两个长度为 n 的整数数组 days 和 apples ,返回你可以吃掉的苹果的最大数目。

示例 1:

输入:apples = [1,2,3,5,2], days = [3,2,1,4,2] 输出:7 解释:你可以吃掉 7 个苹果:

  • 第一天,你吃掉第一天长出来的苹果。
  • 第二天,你吃掉一个第二天长出来的苹果。
  • 第三天,你吃掉一个第二天长出来的苹果。过了这一天,第三天长出来的苹果就已经腐烂了。
  • 第四天到第七天,你吃的都是第四天长出来的苹果。

示例 2:

输入:apples = [3,0,0,0,0,2], days = [3,0,0,0,0,2] 输出:5 解释:你可以吃掉 5 个苹果:

  • 第一天到第三天,你吃的都是第一天长出来的苹果。
  • 第四天和第五天不吃苹果。
  • 第六天和第七天,你吃的都是第六天长出来的苹果。

提示:

apples.length == n days.length == n 1 <= n <= 2 * 104 0 <= apples[i],
days[i] <= 2 * 104 只有在 apples[i] = 0 时,days[i] = 0 才成立

此题为力扣221周周赛的第二题,当时做的时候被逻辑绕晕了,然后在题解里看到的一个大佬用堆写的,更新时直接pop掉过期的苹果,想法真的很精妙,在此把代码贴出来,并加上了注解,与大家分享。

题解:

用heap数据结构主要是因为它可以直接pop掉头部,比较方便,此处也可以用队列实现。

class Solution:
    def eatenApples(self, apples: List[int], days: List[int]) -> int:
        import heapq
        i,count,heap,n = 0,0,[],len(apples)
        while i<n or heap:
            if i<n:
                if apples[i]!=0:
                    heapq.heappush(heap,[days[i]+i,apples[i]])      #添加今天的新苹果
                #print("添加:", heap)
            #判断最早放入的苹果数量是否已经消耗完,或保质期以超过现在的日期
            while heap and (heap[0][0]<=i or heap[0][1]<=0):    
                heapq.heappop(heap)                             #移除最早放入的过期的
                #print("移除:", heap)
            if heap:                                            #吃苹果
                count+=1
                heap[0][1]-=1
            i+=1
        return count

作者:codingking-b
链接:https://leetcode-cn.com/problems/maximum-number-of-eaten-apples/solution/python-you-xian-ji-dui-lie-by-codingking-odxu/
来源:力扣(LeetCode)https://leetcode-cn.com/problems/maximum-number-of-eaten-apples/

你可能感兴趣的:(刷题笔记,leetcode,python)