前言
⭐Hello!这里是欧_aita的博客。
⭐今日语录: 成功的关键在于对目标的持久追求。
⭐个人主页:欧_aita
ψ(._. )>⭐个人专栏:
数据结构与算法
数据库
合并区间问题📕
现实应用
- 合并重叠区间: 将给定的一组区间合并成尽可能少的不相交或相邻的区间。
- 区间调度: 在一系列任务或活动中,每个任务有一个开始时间和结束时间,选择尽可能多的任务而不相互冲突。
- 时间区间问题: 处理一系列时间区间,例如查找某个时间点同时发生的事件。
- 日程安排: 对一组日程进行调度,以确定可以安排多少个活动而不冲突。
大致思路
代码实现
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
typedef pair<int, int> PII;
const int N = 100010;
int n;
vector<PII> segs;
// 区间合并后的区间个数
// 1. 按区间左端点排序
// 2. 左端点st 右端点ed
void merge(vector<PII>& segs) {
vector<PII> res;
sort(segs.begin(), segs.end());
int st = -2e9, ed = -2e9;
for (auto seg <