【C++刷题】力扣-#252-会议室

题目描述

给定一个会议时间安排的数组 intervals,每个 intervals[i] 表示一个会议的开始和结束时间。判断一个人是否能够参加所有的会议(即没有会议是重叠的)。

示例

示例 1:

bash 复制代码
输入:intervals = [[0,30],[5,10],[15,20]]
输出:false

示例 2:

bash 复制代码
输入:intervals = [[7,10],[9,12]]
输出:true

题解

这个问题可以通过排序和贪心算法来解决。

  1. 排序:首先根据会议的开始时间对 intervals 进行排序。
  2. 检查重叠:遍历排序后的会议时间,对于每个会议,检查它的开始时间是否大于或等于前一个会议的结束时间。
    ○ 如果是,说明没有重叠,继续检查下一个会议。
    ○ 如果不是,说明存在重叠,返回 false。
  3. 返回结果:如果所有会议检查完毕,没有发现重叠,返回 true。

代码实现

cpp 复制代码
bool canAttendMeetings(vector<vector<int>>& intervals) {
    sort(intervals.begin(), intervals.end());
    for (int i = 1; i < intervals.size(); i++) {
        if (intervals[i][0] < intervals[i-1][1]) {
            return false;
        }
    }
    return true;
}

复杂度分析

● 时间复杂度:O(n log n),其中 n 是会议的数量。主要时间消耗在排序上。

● 空间复杂度:O(1),因为我们只使用了常数个额外变量。

这个算法的优势在于它的时间效率较高,只需要一次遍历即可判断所有会议是否冲突,且不需要额外的存储空间。

相关推荐
AIpanda888几秒前
当智能化工具应用于企业,如何借助AI销冠系统提升工作效率?
算法
惆怅客1233 分钟前
在 vscode 中断点调试 ROS2 C++ 的办法
c++·vscode·调试·ros 2
进击的小头6 分钟前
01_嵌入式C与控制理论入门:从原理到MCU实战落地
c语言·单片机·算法
what_20188 分钟前
list 对象里面 嵌套list对象,对象的属性 有浮点数,list<浮点数> 对list对象求均值
算法·均值算法
眠りたいです9 分钟前
Docker:镜像的运行实体-Docker Container
java·运维·c++·docker·容器·eureka
wanghowie14 分钟前
01.09 Java基础篇|算法与数据结构实战
java·数据结构·算法
ComputerInBook15 分钟前
C++ 标准提供的 thread (线程)之 join() 函数示例(windows平台)
c++·线程·join函数
快乐的划水a15 分钟前
嵌入式时间测量方法总结
c++·stm32·单片机
郝学胜-神的一滴23 分钟前
GLSL语法详解:从入门到实战
c++·算法·图形渲染
qq_4634084224 分钟前
React Native跨平台技术在开源鸿蒙中使用内置的`fetch` API或者第三方库如`axHarmony`来处理网络通信HTTP请求
javascript·算法·react native·react.js·http·开源·harmonyos