LeetCode 题解工作台
避免洪水泛滥
你的国家有 10 9 个湖泊,所有湖泊一开始都是空的。当第 n 个湖泊下雨前是空的,那么它就会装满水。如果第 n 个湖泊下雨前是 满的 ,这个湖泊会发生 洪水 。你的目标是避免任意一个湖泊发生洪水。 给你一个整数数组 rains ,其中: rains[i] > 0 表示第 i 天时,第 rains[…
5
题型
6
代码语言
3
相关题
当前训练重点
中等 · 数组·哈希·扫描
答案摘要
我们将所有晴天都存入 数组或者有序集合中,使用哈希表 记录每个湖泊最近一次下雨的日期。初始化答案数组 每个元素为 。 接下来,我们遍历 数组。对于每个下雨的日期 ,如果 存在,说明该湖泊在之前下过雨,那么我们需要找到 数组中第一个大于 的日期,将其替换为下雨的日期,否则说明无法阻止洪水,返回空数组。对于没下雨的日期 ,我们将 存入 数组中,并且将 置为 。
Interview AiBoxInterview AiBox 实时 AI 助手,陪你讲清 数组·哈希·扫描 题型思路
题目描述
你的国家有 109 个湖泊,所有湖泊一开始都是空的。当第 n 个湖泊下雨前是空的,那么它就会装满水。如果第 n 个湖泊下雨前是 满的 ,这个湖泊会发生 洪水 。你的目标是避免任意一个湖泊发生洪水。
给你一个整数数组 rains ,其中:
rains[i] > 0表示第i天时,第rains[i]个湖泊会下雨。rains[i] == 0表示第i天没有湖泊会下雨,你 必须 选择 一个 湖泊并 抽干 这个湖泊的水。
请返回一个数组 ans ,满足:
ans.length == rains.length- 如果
rains[i] > 0,那么ans[i] == -1。 - 如果
rains[i] == 0,ans[i]是你第i天选择抽干的湖泊。
如果有多种可行解,请返回它们中的 任意一个 。如果没办法阻止洪水,请返回一个 空的数组 。
请注意,如果你选择抽干一个装满水的湖泊,它会变成一个空的湖泊。但如果你选择抽干一个空的湖泊,那么将无事发生。
示例 1:
输入:rains = [1,2,3,4] 输出:[-1,-1,-1,-1] 解释:第一天后,装满水的湖泊包括 [1] 第二天后,装满水的湖泊包括 [1,2] 第三天后,装满水的湖泊包括 [1,2,3] 第四天后,装满水的湖泊包括 [1,2,3,4] 没有哪一天你可以抽干任何湖泊的水,也没有湖泊会发生洪水。
示例 2:
输入:rains = [1,2,0,0,2,1] 输出:[-1,-1,2,1,-1,-1] 解释:第一天后,装满水的湖泊包括 [1] 第二天后,装满水的湖泊包括 [1,2] 第三天后,我们抽干湖泊 2 。所以剩下装满水的湖泊包括 [1] 第四天后,我们抽干湖泊 1 。所以暂时没有装满水的湖泊了。 第五天后,装满水的湖泊包括 [2]。 第六天后,装满水的湖泊包括 [1,2]。 可以看出,这个方案下不会有洪水发生。同时, [-1,-1,1,2,-1,-1] 也是另一个可行的没有洪水的方案。
示例 3:
输入:rains = [1,2,0,1,2] 输出:[] 解释:第二天后,装满水的湖泊包括 [1,2]。我们可以在第三天抽干一个湖泊的水。 但第三天后,湖泊 1 和 2 都会再次下雨,所以不管我们第三天抽干哪个湖泊的水,另一个湖泊都会发生洪水。
提示:
1 <= rains.length <= 1050 <= rains[i] <= 109
解题思路
方法一:贪心 + 二分查找
我们将所有晴天都存入 数组或者有序集合中,使用哈希表 记录每个湖泊最近一次下雨的日期。初始化答案数组 每个元素为 。
接下来,我们遍历 数组。对于每个下雨的日期 ,如果 存在,说明该湖泊在之前下过雨,那么我们需要找到 数组中第一个大于 的日期,将其替换为下雨的日期,否则说明无法阻止洪水,返回空数组。对于没下雨的日期 ,我们将 存入 数组中,并且将 置为 。
遍历结束,返回答案数组。
时间复杂度 ,空间复杂度 。其中 为 数组的长度。
class Solution:
def avoidFlood(self, rains: List[int]) -> List[int]:
n = len(rains)
ans = [-1] * n
sunny = SortedList()
rainy = {}
for i, v in enumerate(rains):
if v:
if v in rainy:
idx = sunny.bisect_right(rainy[v])
if idx == len(sunny):
return []
ans[sunny[idx]] = v
sunny.discard(sunny[idx])
rainy[v] = i
else:
sunny.add(i)
ans[i] = 1
return ans
复杂度分析
| 指标 | 值 |
|---|---|
| 时间 | Depends on the final approach |
| 空间 | Depends on the final approach |
面试官常问的追问
外企场景- question_mark
Look for efficient use of hash table or priority queue.
- question_mark
Evaluate the approach to handle the greedy choice of drying lakes.
- question_mark
Check if the candidate can explain time and space complexities in terms of their solution.
常见陷阱
外企场景- error
Failing to correctly track the last rain day for each lake, leading to wrong dry-day decisions.
- error
Choosing the wrong lake to dry, causing a flood despite avoiding it initially.
- error
Not considering edge cases where drying any lake leads to a flood.
进阶变体
外企场景- arrow_right_alt
What if there’s no lake to dry (i.e., no 0 in the array)?
- arrow_right_alt
How would you modify your approach if multiple lakes can be dried on the same day?
- arrow_right_alt
Can you optimize the space usage while still maintaining O(log n) time complexity?