首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >LeetCode 1942. 最小未被占据椅子的编号(set)

LeetCode 1942. 最小未被占据椅子的编号(set)

作者头像
Michael阿明
发布2021-09-06 11:22:45
发布2021-09-06 11:22:45
46400
代码可运行
举报
运行总次数:0
代码可运行

文章目录

1. 题目

有 n 个朋友在举办一个派对,这些朋友从 0 到 n - 1 编号。 派对里有 无数 张椅子,编号为 0 到 infinity 。 当一个朋友到达派对时,他会占据 编号最小未被占据的椅子。

比方说,当一个朋友到达时,如果椅子 0 ,1 和 5 被占据了,那么他会占据 2 号椅子。 当一个朋友离开派对时,他的椅子会立刻变成未占据状态。 如果同一时刻有另一个朋友到达,可以立即占据这张椅子。

给你一个下标从 0 开始的二维整数数组 times ,其中 times[i] = [arrivali, leavingi] 表示第 i 个朋友到达和离开的时刻,同时给你一个整数 targetFriend 。 所有到达时间 互不相同

请你返回编号为 targetFriend 的朋友占据的 椅子编号 。

代码语言:javascript
代码运行次数:0
运行
复制
示例 1:
输入:times = [[1,4],[2,3],[4,6]], targetFriend = 1
输出:1
解释:
- 朋友 0 时刻 1 到达,占据椅子 0 。
- 朋友 1 时刻 2 到达,占据椅子 1 。
- 朋友 1 时刻 3 离开,椅子 1 变成未占据。
- 朋友 0 时刻 4 离开,椅子 0 变成未占据。
- 朋友 2 时刻 4 到达,占据椅子 0 。
朋友 1 占据椅子 1 ,所以返回 1 。

示例 2:
输入:times = [[3,10],[1,5],[2,6]], targetFriend = 0
输出:2
解释:
- 朋友 1 时刻 1 到达,占据椅子 0 。
- 朋友 2 时刻 2 到达,占据椅子 1 。
- 朋友 0 时刻 3 到达,占据椅子 2 。
- 朋友 1 时刻 5 离开,椅子 0 变成未占据。
- 朋友 2 时刻 6 离开,椅子 1 变成未占据。
- 朋友 0 时刻 10 离开,椅子 2 变成未占据。
朋友 0 占据椅子 2 ,所以返回 2 。
 
提示:
n == times.length
2 <= n <= 10^4
times[i].length == 2
1 <= arrivali < leavingi <= 10^5
0 <= targetFriend <= n - 1
每个 arrivali 时刻 互不相同 。

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/the-number-of-the-smallest-unoccupied-chair 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • 使用 set 对 <离开时间,拿的号码> 自动排序,当前人要取号之前,先将时间到了要离开的人的号放回
  • 再从没有取的号码里,拿出最小的,使用 set 实现
代码语言:javascript
代码运行次数:0
运行
复制
class Solution {
public:
    int smallestChair(vector<vector<int>>& times, int targetFriend) {
        int n = times.size();
        vector<int> id(n);
        iota(id.begin(), id.end(), 0); // 编号 0 - n-1
        sort(id.begin(), id.end(), [&](auto a, auto b){
            if(times[a][0] == times[b][0])
                return times[a][1] < times[b][1];
            return times[a][0] < times[b][0];
        }); // 排序先来的先取号,先走的,先放回号码
        set<int> untake(id.begin(), id.end()); // 没拿的号码
        set<pair<int,int>> leaveTime; // 离开时间,拿的号码,自动排序,时间早的先离开
        for(auto idx : id)
        {
            while(!leaveTime.empty() && (*leaveTime.begin()).first <= times[idx][0]) 
            {   // 到达之前,有人离开
                int num = (*leaveTime.begin()).second;//拿的号码
                untake.insert(num);//放回号码
                leaveTime.erase(leaveTime.begin());//离开了
            }
            if(idx == targetFriend)
                return *untake.begin();
            int takeNum = *untake.begin();//分配号码
            untake.erase(takeNum);
            leaveTime.insert({times[idx][1], takeNum});
        }
        return -1;
    }
};

264 ms 71.2 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/07/25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 1. 题目
  • 2. 解题
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档