Python解法:
import heapq
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 计算成功举办活动需要多少名主持人
# @param n int整型 有n个活动
# @param startEnd int整型二维数组 startEnd[i][0]用于表示第i个活动的开始时间,startEnd[i][1]表示第i个活动的结束时间
# @return int整型
#
class Solution:
def minmumNumberOfHost(self , n: int, startEnd: List[List[int]]) -> int:
heap = []
# 关键1:按「开始时间升序 + 结束时间升序」排序,确保贪心逻辑有效
startEnd.sort(key=lambda x: (x[0],x[1]))
# 关键2:堆非空 + 当前会议开始时间 >= 堆顶(最早结束时间)→ 复用主持人
for start,end in startEnd:
if heap and start >= heap[0]:
heapq.heappop(heap)# 弹出旧结束时间(主持人空闲)
heapq.heappush(heap,end)# 压入当前会议结束时间(更新主持人可用时间)
return len(heap)

京公网安备 11010502036488号