🗒️1942. 最小未被占据椅子的编号
2025-8-11
| 2025-8-11
0  |  阅读时长 0 分钟
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 的空间复杂度,使其不要与人员数量相挂钩。

📎 参考

  • 【题单】常用数据结构(前缀和/差分/栈/队列/堆/字典树/并查集/树状数组/线段树)
  • 1801. 积压订单中的订单总数3296. 移山所需的最少秒数
    Loading...