904 水果成篮-中等
题目:
你正在探访一家农场,农场从左到右种植了一排果树。这些树用一个整数数组 fruits
表示,其中 fruits[i]
是第 i
棵树上的水果 种类 。
你想要尽可能多地收集水果。然而,农场的主人设定了一些严格的规矩,你必须按照要求采摘水果:
你只有 两个 篮子,并且每个篮子只能装 单一类型 的水果。每个篮子能够装的水果总量没有限制。
你可以选择任意一棵树开始采摘,你必须从 每棵 树(包括开始采摘的树)上 恰好摘一个水果 。采摘的水果应当符合篮子中的水果类型。每采摘一次,你将会向右移动到下一棵树,并继续采摘。
一旦你走到某棵树前,但水果不符合篮子的水果类型,那么就必须停止采摘。
给你一个整数数组 fruits
,返回你可以收集的水果的 最大 数目。
分析:
该题目重在理解题目。
Fruits 数组中的元素,代表水果的种类编号,即同一个编号表示同一种水果
你只可采摘两种类型的水果,即子数组中不同的元素个数不能超过两个
所以,这道题就变成了求子数组中连续元素种类不超过2的最大长度。
滑动窗口算法。
通过 map 维护元素的种类,一旦种类超过两种,那么左指针就要移动,直到元素移除,map 不超过两种为止
那么,此时左右指针的距离就是子数组的长度,求最大子数组长度
// date 2023/11/21
func totalFruit(fruits []int) int {
ans := 0
left, right := 0, 0
size := len(fruits)
set := make(map[int]int, 16)
for right < size {
set[fruits[right]]++
right++
for len(set) > 2 {
set[fruits[left]]--
if set[fruits[left]] == 0 {
delete(set, fruits[left])
}
left++
}
if ans < right-left {
ans = right - left
}
}
return ans
}
最后更新于