AcWing906 区间分组 贪心 运算符重载

该博客探讨了一道关于区间划分的问题,通过贪心策略尽可能减少区间被分成的组数。算法思路是使用优先队列,按区间左端点排序,确保每个新加入的区间与当前最右端无交集,从而达到最小化组数的目标。输入输出格式及样例也一同给出,适合算法学习者参考。
摘要由CSDN通过智能技术生成

实在受不了数论的折磨于是
感觉贪心友好多了but不严谨证明多少带点运气成分((

题目:
给定 N 个闭区间 [ai,bi],请你将这些区间分成若干组,使得每组内部的区间两两之间(包括端点)没有交集,并使得组数尽可能小。

输出最小组数。

输入格式
第一行包含整数 N,表示区间数。

接下来 N 行,每行包含两个整数 ai,bi,表示一个区间的两个端点。

输出格式
输出一个整数,表示最小组数。

数据范围
1≤N≤1e5,
−1e9≤ai≤bi≤1e9
输入样例:
3
-1 1
2 4
3 5
输出样例:
2

#include<iostream>
#include<algorithm>
#include<queue>
using namespace std;
const int N = 100010;
struct Range {
	int l, r;
	bool operator< (const Range& w)const {
		return l < w.l;
	}
};
Range range[N];
int main() {
	int n;
	cin >> n;
	for (int i = 0; i < n; i++) {
		int l, r;
		cin >> l >> r;
		range[i] = { l,r };
	}
	priority_queue<int, vector<int>, greater<int>>heap;
	sort(range, range + n);
	for (int i = 0; i < n; i++) {
		if (heap.empty() || heap.top() >= range[i].l) {
			//如果当前空或者最右端严格>=最左端
			heap.push(range[i].r);//那就要新加一个组
		}
		else {
			heap.pop();
			heap.push(range[i].r);
		}
	}
	cout << heap.size();
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值