文章目录

  • 1. 题目
  • 2. 解题

1. 题目

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

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

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

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

示例 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 实现
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-1sort(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阿明),一起加油、一起学习进步!

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

  1. LeetCode 1631. 最小体力消耗路径(DFS + 二分查找)

    文章目录 1. 题目 2. 解题 1. 题目 你准备参加一场远足活动.给你一个二维 rows x columns 的地图 heights ,其中 heights[row][col] 表示格子 (row ...

  2. leetcode 64. 最小路径和(递归 / 动态规划解法图解)(Java版)

    题目 leetcode 64. 最小路径和 提示: m == grid.length n == grid[i].length 1 <= m, n <= 200 0 <= grid[i ...

  3. LeetCode 64最小路径和65有效数字66加一

    原创公众号:bigsai 专注于Java.数据结构与算法,一起进大厂不迷路! 关注后回复进群即可加入力扣打卡群,欢迎划水.近期打卡: LeetCode打卡 52八皇后Ⅱ&53最大子序和& ...

  4. LeetCode 632. 最小区间(排序+滑动窗口)

    文章目录 1. 题目 2. 解题 1. 题目 你有 k 个升序排列的整数数组. 找到一个最小区间,使得 k 个列表中的每个列表至少有一个数包含在其中. 我们定义如果 b-a < d-c 或者在 ...

  5. leetcode 1631. 最小体力消耗路径(并查集)

    你准备参加一场远足活动.给你一个二维 rows x columns 的地图 heights ,其中 heights[row][col] 表示格子 (row, col) 的高度.一开始你在最左上角的格子 ...

  6. LeetCode 1981. 最小化目标值与所选元素的差(DP)

    文章目录 1. 题目 2. 解题 1. 题目 给你一个大小为 m x n 的整数矩阵 mat 和一个整数 target . 从矩阵的 每一行 中选择一个整数,你的目标是 最小化 所有选中元素之 和 与 ...

  7. LeetCode 483. 最小好进制(二分查找)

    文章目录 1. 题目 2. 解题 1. 题目 对于给定的整数 n, 如果 n 的 k(k>=2)进制数的所有数位全为1,则称 k(k>=2)是 n 的一个好进制. 以字符串的形式给出 n, ...

  8. LeetCode 963. 最小面积矩形 II

    文章目录 1. 题目 2. 解题 1. 题目 给定在 xy 平面上的一组点,确定由这些点组成的任何矩形的最小面积,其中矩形的边不一定平行于 x 轴和 y 轴. 如果没有任何矩形,就返回 0. 示例 1 ...

  9. LeetCode 939. 最小面积矩形(哈希)

    文章目录 1. 题目 2. 解题 1. 题目 给定在 xy 平面上的一组点,确定由这些点组成的矩形的最小面积,其中矩形的边平行于 x 轴和 y 轴. 如果没有任何矩形,就返回 0. 示例 1: 输入: ...

最新文章

  1. 6-6.用HLSL定义点光源
  2. 看懂GE Predix ,就看懂了工业互联网
  3. dotnet watch+vs code提升asp.net core开发效率
  4. Eclipse生成SSH传输密钥并实现GitHub的SSH代码提交
  5. soapUI-JDBC Request
  6. AndroidTelephony学习大纲
  7. Pyqt5转化.ui文件到.py文件
  8. 计算机排版自然段视频教程,排版教程(新手电脑排版教程视频)
  9. 《善用佳软:高效能人士的软件应用之道》一导读
  10. 基于STM32单片机的精彩设计实例合集
  11. MySQL —— 查询升序和降序
  12. Python爬取拉钩招聘网,告诉你:这类程序员最赚钱!
  13. 利用Windows系统自带命令手工搞定病毒
  14. mysql 报错“发生系统错误 3.系统找不到指定路径”
  15. Micro API使用
  16. 基于全志A64平台v4l2驱动分析
  17. android 数据库的种类,Android SQLite数据库
  18. Windows XP下如何取消打印机与任务计划的共享
  19. 魅族手机装Xposed框架
  20. 顶级学霸的武汉大学经历

热门文章

  1. 清华大学《操作系统》(九):进程和线程
  2. qmlcanvas绘制3d图形_透视Matplotlib核心功能和工具包 - 绘制3D图形
  3. HTML段落,换行,字符实体
  4. Redis数据库学习笔记
  5. 如何使用CppUnit进行单元测试
  6. 数据结构:将二叉搜索树转换成一个排序的双向链表
  7. ue4集合类型_UE4粒子系统渲染管线概述
  8. C#面试题整理(不带答案)
  9. 泛型(模拟list)
  10. (机器学习/计算机视觉/深度学习)代码