【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),因为我们只使用了常数个额外变量。

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

相关推荐
包饭厅咸鱼15 分钟前
PaddleOCR----制作数据集,模型训练,验证 QT部署(未完成)
算法
无敌最俊朗@28 分钟前
C++ 并发与同步速查笔记(整理版)
开发语言·c++·算法
王哈哈^_^30 分钟前
【完整源码+数据集】课堂行为数据集,yolo课堂行为检测数据集 2090 张,学生课堂行为识别数据集,目标检测课堂行为识别系统实战教程
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
夏鹏今天学习了吗1 小时前
【LeetCode热题100(66/100)】寻找两个正序数组的中位数
算法·leetcode·职场和发展
墨染点香1 小时前
LeetCode 刷题【151. 反转字符串中的单词】
算法·leetcode·职场和发展
神仙别闹1 小时前
基于 C++和 Python 实现计算机视觉
c++·python·计算机视觉
ytttr8731 小时前
Landweber迭代算法用于一维、二维图像重建
人工智能·算法·机器学习
feifeigo1231 小时前
Matlab编写压缩感知重建算法集
人工智能·算法·matlab
眠りたいです2 小时前
基于脚手架微服务的视频点播系统-客户端业务逻辑处理部分(三)-客户端主体部分完结
c++·微服务·云原生·架构·json·restful·qt6.7
烛衔溟2 小时前
C语言多级指针与函数指针:指针的高级用法
c语言·算法