牛客 D 无限的韵律源点 (对顶堆+滑动窗口)

牛客 D 无限的韵律源点 (对顶堆+滑动窗口)

题目链接

思路

本题的重点在于 recent best部分,即指定下标和指定长度的区间 k 最大值,这实际上是区间 k 最值的***版。因此可以选择主席树,划分树等数据结构直接维护。由于本题固定长度的限制,实际上可以借助对顶堆,通过滑动窗口的思想直接维护。开一个小根堆,维护前rb大的值,盛下的维护后ra-rb小的值
可以直接用set替代堆,实现两个部分的维护

代码

#include<iostream>
#include<set>
#include<algorithm>
#include<vector>

using namespace std;
using ll = long long;
using pii = pair<int, int>;

#define x first
#define y second

int main() {
	int n, b, ra, rb;
	cin >> n >> b >> ra >> rb;
	vector<int> nums(n);
	for (int i = 0; i < n; i++) cin >> nums[i];
	multiset<pii> s, sx;
	multiset<pii, greater<pii>> sy;

	ll sum1 = 0, sum2 = 0;


	ll ans = 0;
	for (int i = 0; i < n; i++) {
		s.insert({ nums[i],i });
		sum1 += nums[i];
		while (s.size() > b) {
			sum1 -= s.begin()->x;
			s.erase(s.begin());
		}
		if (i >= ra) {
			int j = i - ra;
			if (sx.count({ nums[j],j })) sx.erase({ nums[j],j }), sum2 -= nums[j];
			else if (sy.count({ nums[j],j })) sy.erase({ nums[j],j });
		}
		if (sx.size() && nums[i] >= sx.begin()->first) sx.insert({ nums[i],i }), sum2 += nums[i];
		else sy.insert({ nums[i],i });
		
		while (sx.size() < rb && sy.size()) {
			sx.insert(*sy.begin());
			sum2 += sy.begin()->x;
			sy.erase(sy.begin());
		}
		while(sx.size()>rb){
			sum2 -= sx.begin()->x;
			sy.insert(*sx.begin());
			sx.erase(sx.begin());
		}
		ans = max(ans, sum1 + sum2);
	}
	cout << ans << endl;
	return 0;
}

思路2

发现了一种牛批的线段树做法,下面贴上大佬代码(这种做法只适用于固定长度(或每次长度常数级别的变化))

#include<iostream>
#include<set>
#include<algorithm>
using namespace std;
typedef long long ll;

#define N 200000

int i, j, k, n, m, t, a[N + 50], mp[N + 50], it;
set<pair<int, int> > s1, s2;
ll res, tot;

struct SB {
#define md ((l+r)/2)
#define ls (id*2)
#define rs (ls+1)
	ll f[N * 4 + 50], g[N * 4 + 50];//f元素的个数,g区间和
	void add(int id, int l, int r, int x, int y) {
		if (l == r) {
			f[id] += y; g[id] += mp[l] * y; return;
		}
		if (x <= md)add(ls, l, md, x, y);
		else add(rs, md + 1, r, x, y);
		f[id] = f[ls] + f[rs]; g[id] = g[ls] + g[rs];
		//cout<<"nmsl "<<l<<' '<<r<<' '<<f[id]<<' '<<g[id]<<endl;
	}
	ll get(int id, int l, int r, int w) {
		//cout<<"NMSL "<<id<<' '<<l<<' '<<r<<' '<<w<<' '<<f[id]<<' '<<g[id]<<endl;
		if (f[id] < w)exit(1);
		if (l == r) {
			return 1ll * mp[l] * w;
		}
		if (f[id] == w) {
			return g[id];
		}
		if (f[rs] >= w) {
			return get(rs, md + 1, r, w);
		}
		return g[rs] + get(ls, l, md, w - f[rs]);
	}
}sb, sb2;

int main() {
	ios::sync_with_stdio(0); cin.tie(0);
	int ra, rb;
	cin >> n >> m >> ra >> rb;
	for (i = 1; i <= n; i++) {
		cin >> a[i]; mp[++it] = a[i];
	}
	sort(mp + 1, mp + it + 1); it = unique(mp + 1, mp + it + 1) - mp - 1;
	for (i = 1; i <= n; i++) {
		a[i] = lower_bound(mp + 1, mp + it + 1, a[i]) - mp;
		//cout<<"nmsl "<<i<<' '<<a[i]<<endl;
	}
	for (i = 1; i <= n; i++) {
		//cout<<"NMSL "<<i<<' '<<it<<endl;
		sb.add(1, 1, it, a[i], 1);
		sb2.add(1, 1, it, a[i], 1);
		if (i > ra) {
			sb2.add(1, 1, it, a[i - ra], -1);
		}
		//cout<<"nmsl"<<endl;
		tot = sb.get(1, 1, it, min(i, m)) + sb2.get(1, 1, it, min(i, rb));
		res = max(res, tot);
	}
	cout << res;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/559692.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

全志R329 AP6256 蓝牙调试

1、在全志r329平台移植AP6256,移植了一个星期,记录下过程。 2、本来产品只需要wifi,不需要蓝牙的。但是我们使用的是正基AP6256的wifi、BT二合一的模组。 该模块只要有BT功能就需要做BT的3C认证。 好吧。 1、获取调试蓝牙的几个工具 两个方法: 1.1、方法一:自己交叉…

蓝桥杯2024年第十五届省赛真题-爬山

贪心优先队列的题&#xff0c;贪心会漏一个情况&#xff0c;不知道怎么处理&#xff0c;这里直接打表了 2 1 1 48 49 答案是30&#xff0c;贪心是31 专有名词&#xff1a;hack-有新的测试点过不了 #include<bits/stdc.h> using namespace std; #define endl \n #define …

QT C++ sqlite 对多个数据库的操作

//本文描述&#xff0c;QT 对多数据库的操作。 //你可能会想&#xff0c;多数据库的操作时&#xff0c;查询语句怎么知道是哪个数据库。 //QT提供了这样一种构造函数 QSqlQuery(const QSqlDatabase &db) //指定数据库 //在QT6.2.4 MSVC2019调试通过。 //效果见下图&am…

HarmonyOs开发:导航tabs组件封装与使用

前言 主页的底部导航以及页面顶部的切换导航&#xff0c;无论哪个系统&#xff0c;哪个App&#xff0c;都是最常见的功能之一&#xff0c;虽然说在鸿蒙中有现成的组件tabs可以很快速的实现&#xff0c;但是在使用的时候&#xff0c;依然有几个潜在的问题存在&#xff0c;第一&a…

12. MyBatis(二)

源码位置&#xff1a;MyBatis_demo 上篇文章我们学习了MyBatis的定义以及增删查改操作&#xff0c;并且学习了如何在xml文件中编写SQL时使用#{}的方式将参数和对象的属性映射到SQL语句中&#xff0c;上篇的内容已经足以应对大部分场景&#xff0c;本篇文章我们就要学习一下MyBa…

测绘管理与法律法规 | 测绘资质管理办法 | 学习笔记

目录 一、测绘资质概述 二、测绘资质分类与等级 三、审批与管理 四、申请条件 五、审批程序 六、测绘资质证书 七、监督管理 八、违规处理 九、特殊规定 十、审批受理时间要点补充 1. 审批机关决定是否受理的时间 2. 审批机关作出批准与否的决定时间 3. 颁发测绘资…

linux /proc进程文件目录介绍

参考&#xff1a;https://zhuanlan.zhihu.com/p/619966043 有时候想只查出来进程号&#xff0c;可以通过/proc/下查出该进程的运行及执行脚本情况信息 /proc/pid子目录 记录了进程的相关信息cmdline文件&#xff1a;包含了进程启动时使用的完整命令行参数。 cwd符号链接&#x…

29. 【Android教程】折叠列表 ExpandableListView

本节学习一个可折叠的 ListView&#xff0c;可以用在一些需要分类的场景下。通过 ExpandableListView 我们可以首先在 ListView 上展示大的分类&#xff0c;当点击某个类别的时候再将 ListView 做一个展开&#xff0c;展示该类下的所有子类供用户选择。它与 ListView 的不同主要…

考研数学|武忠祥VS张宇,谁讲得更全面❓

张宇和武忠祥都是很好的老师&#xff0c;你肯定也是这么觉得的&#xff0c;你自己也说了&#xff0c;跟着张宇看了几章&#xff0c;感觉不错&#xff0c;那就继续跟着啊&#xff0c;为什么听到同学说武忠祥好&#xff0c;你就动摇了呢。我们对于任何事情都要有自己的思考和规划…

SQL注入简单总结

一、SQL注入是什么 SQL注入即&#xff1a;是指web应用程序对用户输入数据的合法性没有判断或过滤不严&#xff0c;攻击者可以在web应用程序中事先定义好的查询语句的结尾上添加额外的SQL语句&#xff0c;在管理员不知情的情况下实现非法操作&#xff0c;以此来实现欺骗数据库服…

prompt问题【中间不好】

问题1:longchain 关键词在中间容易被忽略掉 Found in the Middle: How Language Models Use Long Contexts Better via Plug-and-Play Positional Encoding 论文对大模型在长文本情况下的性能做了一系列实验研究&#xff0c;发现了一个有趣的“Lost in the middle”现象&#x…

我与C++的爱恋:隐式类型转换

​ ​ &#x1f525;个人主页&#xff1a;guoguoqiang. &#x1f525;专栏&#xff1a;我与C的爱恋 朋友们大家好&#xff0c;本篇内容我们来介绍初始化列表&#xff0c;隐式类型转换以及explicit的内容 一、初始化列表 1.1 构造函数体赋值 在创建对象时&#xff0c;编译器…

【笔试强训】Day3 --- 简写单词 + dd爱框框 + 除2!

文章目录 1. 简写单词2. dd爱框框3. 除2&#xff01; 1. 简写单词 【链接】&#xff1a;简写单词 解题思路&#xff1a;简单模拟题&#xff0c;主要是处理⼀下输⼊的问题。&#xff08;也可以利用string类中的find函数&#xff0c;但时间复杂度会偏高&#xff09; #include …

一套全院级PACS系统源码,实现影像检查的电子预约申请、电子诊断报告、 临床科室设立影像浏览终端等功能

一套全院级PACS系统源码&#xff0c;实现影像检查的电子预约申请、电子诊断报告、 临床科室设立影像浏览终端等功能 一套全院级PACS系统源码&#xff0c;包括放射、CT、超声、内镜、病理等科室影像及信息管理系统的建设&#xff0c;解决医学影像的采集、诊断、传输、存储&#…

电感与磁珠

电感是什么&#xff1f; 电感会通过产生感应电动势的方式来阻碍电流的变化&#xff0c;电流变化率越大&#xff0c;产生的感应电动势越大阻碍电流效果越明显。 [一]品质因数Q: 电感的品质因数Q值定义&#xff1a;电感的Q值也叫作品质因数&#xff0c;其为无功功率除以有功功率…

永恒之蓝复现

目录 一、原理 二、实验环境 三、实验步骤 \1. 查询ip \2. 测试两台主机的连通性 \3. 查询指kali数据库的状态 \4. 此时就可以进行永恒之蓝漏洞扫描&#xff0c;&#xff08;永恒之蓝利用的是ms17_010漏洞&#xff0c;因此到这一步之后的任务就是在kali 里寻找ms17_010漏…

比特币减半倒计时:NFT 生态将受到怎样的影响?

BTC 减半倒计时仅剩不到 1 天&#xff0c;预计在 4 月 20 日迎来减半。当前区块奖励为 6.25 BTC&#xff0c;减半后区块奖励为 3.125 BTC&#xff0c;剩余区块为 253。比特币减半无疑是比特币发展史上最重要的事件之一&#xff0c;每当这一事件临近&#xff0c;整个加密社区都充…

从零开始搭建网站(第二天)

今天把之前的htmlcssjs项目迁移过来&#xff0c;直接使用tspiniavue3vite组合&#xff0c;搭建过程可以看从零开始搭建性能完备的网站-思路过程&#xff08;1&#xff09;_自己架设一个芯参数网站-CSDN博客。之后安装一下volar扩展。迁移过来使用Vue重构时发现之前使用的左右两…

《深入浅出多模态》: 多模态经典模型:BLIP

🎉AI学习星球推荐: GoAI的学习社区 知识星球是一个致力于提供《机器学习 | 深度学习 | CV | NLP | 大模型 | 多模态 | AIGC 》各个最新AI方向综述、论文等成体系的学习资料,配有全面而有深度的专栏内容,包括不限于 前沿论文解读、资料共享、行业最新动态以、实践教程、求职…

计算机网络——GBN协议实现

实验目的 编程模拟实现GBN可靠传输软件 实验内容 C 程序模拟实现Go-Back-N可靠数据传输&#xff0c;需要编写一个发送端程序和一个测试端程序来模拟传输过程 具体流程 1. 编写发送端程序&#xff0c;调用库实现socket连接&#xff0c;然后主要实现滑动窗口&#xff0c;接收…
最新文章