题目链接
题目描述
在一排树中,第 i 棵树产生 tree[i] 型的水果。
你可以从你选择的任何树开始,然后重复执行以下步骤:
- 把这棵树上的水果放进你的篮子里。如果你做不到,就停下来。
- 移动到当前树右侧的下一棵树。如果右边没有树,就停下来。
请注意,在选择一颗树后,你没有任何选择:你必须执行步骤 1,然后执行步骤 2,然后返回步骤 1,然后执行步骤 2,依此类推,直至停止。
你有两个篮子,每个篮子可以携带任何数量的水果,但你希望每个篮子只携带一种类型的水果。
用这个程序你能收集的水果树的最大总量是多少?
示例
示例1:
输入:[0,1,2,2] 输出:3 解释:我们可以收集 [1,2,2] 如果我们从第一棵树开始,我们将只能收集到 [0, 1]。
提示
1 <= tree.length <= 40000-
思路
滑动窗口
维护一个窗口
start, end,和counter,end不断移动并更新总量,当counter的大小大于3时,first右移收缩窗口,并更新总量。题解
滑动窗口
class Solution:def totalFruit(self, fruits: List[int]) -> int:n = len(fruits)start, end = 0, 0ans = 0count = collections.Counter()while end < n:count[fruits[end]] += 1while len(count) > 2:count[fruits[start]] -= 1if count[fruits[start]] == 0:del count[fruits[start]]start += 1ans = max(ans, end - start + 1)end += 1return ans
复杂度分析
时间复杂度:
- 空间复杂度:
