type
status
date
slug
summary
tags
category
icon
password
创建时间
Aug 11, 2025 02:07 PM
有
n
个朋友在举办一个派对,这些朋友从 0
到 n - 1
编号。派对里有 无数 张椅子,编号为 0
到 infinity
。当一个朋友到达派对时,他会占据 编号最小 且未被占据的椅子。- 比方说,当一个朋友到达时,如果椅子
0
,1
和5
被占据了,那么他会占据2
号椅子。
当一个朋友离开派对时,他的椅子会立刻变成未占据状态。如果同一时刻有另一个朋友到达,可以立即占据这张椅子。
给你一个下标从 0 开始的二维整数数组
times
,其中 times[i] = [arrivali, leavingi]
表示第 i
个朋友到达和离开的时刻,同时给你一个整数 targetFriend
。所有到达时间 互不相同 。请你返回编号为
targetFriend
的朋友占据的 椅子编号 。堆(优先队列)§5.1 基础
不能简单地这么算。这也只是知道了他们的顺序(排序算法的作用),并没有达到我们的目的。我们需要他们之间的先后顺序。
因此,我们将到达时间和离开时间分别使用两个数组存储,来进行比较。
优化一下,min_pq 的空间复杂度,使其不要与人员数量相挂钩。