codeforces 754D. Fedor and coupons

本文介绍了一种解决区间重叠问题的方法。该问题要求从给定的n个区间中选出k个,使得这些区间的重叠部分最大。通过将区间按左端点排序并使用优先队列来维护当前k个区间的右端点,可以有效地找到最大重叠区间。

题意比较简单,给定n个区间,选择其中k个区间,并且这k个区间的重叠最大。这个题目当时也是想了很久没有想出来。后来看了题解,觉得这是一个典型的问题,有一般的解题思路。一般的解题思路为,将区间按照左端点从小到大的排序,然后利用优先队列,将排序后的区间的右端点依次进入队列(右端点小的在队首),保持队列中只有k个区间的右端点。用队列的队首减去刚入队区间的左端点,得到的便是队列中k个区间的重叠部分,依次更新,取最大值即可。代码如下:

#include <cstdio>
#include <cstring>
#include <queue>
#include <algorithm>

using namespace std;

const int MAX = 300010;

struct Node1{
	int l, r, p;

	bool operator < (const Node1& args) const {
		return l < args.l;
	}
}a[MAX];

priority_queue<int, vector<int>, greater<int> > q;


int main(int argc, char const *argv[])
{
	/* code */
	int n, k;

	scanf("%d%d", &n, &k);
	for (int i = 1; i<=n; i++){
		scanf("%d%d", &a[i].l, &a[i].r);
		a[i].p = i;
	}

	sort(a+1, a+n+1);

	for (int i = 1; i<k; i++){
		q.push(a[i].r);
	}

	int ans = 0, left = -1, right = -1;

	for (int i = k; i<=n; i++){
		q.push(a[i].r);
		int t = q.top();

		if (ans < t - a[i].l + 1 ){
			ans = t - a[i].l + 1;
			left = a[i].l;
			right = t;
		}
		q.pop();
	}

//	printf("%d %d\n", left, right);

	printf("%d\n", ans);

	if (ans == 0){
		for (int i = 1; i<k; i++){
			printf("%d ", i);
		}
		printf("%d\n", k);
	}else{
		int i, j;
		for (i = 1, j = 1; j<k; i++){
			if (a[i].l <= left && a[i].r >= right){
				printf("%d ", a[i].p);
				j++;
			}
		}

		for (; i<=n; i++) if (a[i].l <= left && a[i].r >= right){
			printf("%d\n", a[i].p);
			break;
		}
	}

	return 0;
}


内容概要:本研究聚焦于绿电直连型电氢氨园区的优化运行,提出一种集成绿色电力直接供给、电解水制氢及氢气合成氨工艺的综合能源系统架构。通过建立包含风光发电、电解槽、氨合成反应器、储氢罐、电网交互及多类型负荷在内的系统模型,综合考虑绿电直供优先、能量梯级利用与多能互补原则,构建以系统综合运行成本最小化为目标的优化调度模型。研究采用Matlab与Python工具进行算法求解和仿真分析,利用实际气象与负荷数据完成案例验证,评估了不同运行策略下系统的经济性、可再生能源消纳能力与碳减排效益,为新型电氢氨一体化园区的规划与运行提供了理论依据和技术支撑。; 适合人群:具备一定电力系统、新能源或化工背景的研究生、科研人员及从事综合能源系统规划与优化工作的工程技术人员。; 使用场景及目标:①用于科研学习,理解电-氢-氨多能转换系统的建模与优化方法;②为工业园区的低碳化、智能化改造提供技术参考与决策支持;③作为开发类似综合能源管理系统的理论基础。; 阅读建议:此资源包含完整的模型代码、数据与论文,使用者应结合代码仔细研读论文中的模型构建部分,重点关注目标函数与约束条件的设计逻辑,并尝试修改参数进行仿真,以深入掌握优化算法在实际系统中的应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值