《洛谷深入浅出进阶篇》 P1496火烧赤壁——初识离散化

news2025/1/20 3:51:42

上链接:

P1496 火烧赤壁 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)icon-default.png?t=N7T8https://www.luogu.com.cn/problem/P1496上题干:

有一组序列,[-2^31,2^31] , 现在给你n次操作,每一次操作给出两个整数l,r,代表一个子区间的左端点和右端点,[l,r)这就算覆盖一次。求所有的被覆盖的区间的长度

 例如:现在有一个序列:

给你三对数字,代表着区间的左端点和右端点,你分别对这些区间进行染色:

[1,3) 

[ 2,6)

[4,8) 

可以求出,经过这三次操作,被覆盖的区间的长度:

由于数据很小,所以我们可以用数组标记法:

枚举每次给出的区间,我们将区间内的数字打上标记,然后计算所有被打上标记的数有多少个就行了。

可以求出一共7个格子被覆盖了。

那么假如我给出以下的数据,数组标记法还能用吗?

[-2^31,-2^16)

[-65462131,-16846952)

[0,465)

[241,1321464)

[32137946,2^31)

首先,我们可以看出来,数组标记法,一定是行不通的。

首先数组下标是不能为负数,另外,数据达到了2^31,远远超出了数组能开辟的空间

时空复杂度也是个惊人数字

所以我们必须想办法来优化我们的思路。

其实

对于我们每一个给出的区间,

它们被覆盖的长度就是(右端点-左端点)

只不过有些区间是互相有一部分覆盖了而已。

那么应该怎么办呢?

有些人可能会想,我们只要计算出总长度,然后减去一次重复的区域。

这样或许可以,但,我们可以从根本入手

我们只需要想办法将这些会重复计算的地方只计算一次,那么问题就迎难而解了。

怎么才能只计算一次?————单元化计算(其实这也就是数组标记的思想)

还是上面那个例子:

给出三对区间

第一对区间:[1,3)

找到这个区间的两个端点:1,3

将 [1,3) 所在的区间打上标记(别忘记左闭右开)

也就是,  1  , 2 被打上了标记(这标记有什么用,后面就知道了)

第二对区间:[2,6) 

找到这个区间的端点:2,6

将 [2,6) 所在的区间打上标记

也就是,  2,3,4,5  被打上了标记

第三对区间:[4,8)

依次类推:

那么被打上标记的数字就是这些:

-3  -2 -1  0  1  2  3  4  5  6  7  8 9 10 11 

我们只要对所有打上标记的数字进行一项操作:ans = a[i+1] - a[i]   (差分的思想)

并将这个操作累加起来:ans += a[i+1] - a[i]   

ans = 2-1 + 3-2  + 4-3 + 5-4  + 6-5 + 7-6  + 8-7 = 7

这样的话,我们就不需要考虑会不会有重复区间的情况了,因为所有的数据只算了一遍

到这里,可能有些人坐不住了,你这有啥用啊,这么麻烦,还不如我直接手算呢。

欸,别急,这些只是小数据罢了,等到它是大数据的时候,就很有效果了。

另外,这样的操作,虽然看上去复杂,但是很好实现啊,你难道没发现每一步都是程序化的步骤么,所以有时候我们要站在电脑的角度去思考,瞪眼法虽好,但是很难以用程序来实现。

所以我们就可以引入离散化了(排序,去重,二分查找)

将每一对区间的左右端点当成一个个散点,将其放入数组里面:(这里不清楚的就去看看离散化的概念,很简单的,等你明白离散化是啥了之后再回来看看)

一共六组数字

[-2^31,-2^16)

[-65462131,-16846952)

[0,465)

[241,1321464)

[32137946,2^31)

数组下标12345678910
散点-2^31-2^16-65462131-1684695204652411321464321379462^31

将这一串数字进行排序:

数组下标12345678910
散点-2^31-65462131-16846952-2^1602414561321464321379462^31

紧接着把这个数组进行去重:(本组数据没有重复的,所以忽略) 

离散化的最后一步就是二分查找数据的位置

并结合我们刚刚说过的概念:单元化处理。

还记得单元化处理的第一步是什么吗?(翻上去看看)

找到第一对区间的端点在数组中的位置:(用二分查找找端点,这也就是为什么我们要去重的原因)

第一对端点:-2^31,   -2^16

可以用lower_bound()来进行二分

也可以用手动二分查找

得到位置:1,4

所以我们给[1,4)打上标记(不知道为啥打标记的翻上去看那个更简单的例子,再简单描述一下就是为了方便一项一项地处理,并且所有的数只会计算一次,不信的话你随便写几对数字模拟一下)

打标记:flag[i]=1

以此类推。

最后一步就是单项求和:

如果这个数字被打上了标记,那么我们就进行单元化处理 ans+= a[i+1] - a[i]

最后输出ans就好了

上代码:

const int N = 2e4 + 10;
int n, l[N], r[N], flag[2 * N], temp[2 * N], a,b ;
long long fn[2 * N], ans;
int main()
{
	cin >> n;
	for (int i = 1; i <= n; i++)
	{
		cin >> l[i] >> r[i];
		temp[++a] = l[i];
		temp[++a] = r[i];
	}
	sort(temp + 1, temp + 1 + a);
	for (int i = 1; i <= a;i++)
	{
		if (i == 1 or temp[i] != temp[i - 1])fn[++b] = temp[i];
	}
	for (int i = 1; i <= n; i++)
	{
		int L = lower_bound(fn + 1, fn + 1 + b, l[i]) - fn;
		int R = lower_bound(fn + 1, fn + 1 + b, r[i]) - fn;
		for (int j = L; j < R; j++)
			flag[j] = 1;
	}
	for (int i = 1; i < b; i++)
		if (flag[i])ans += fn[i + 1] - fn[i];
	cout << ans;
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

设计测试用例的6种基本原则

设计测试用例的基本原则&#xff0c;对于软件测试非常重要&#xff0c;这些原则有助于设计出高质量、全面、有效的测试用例&#xff0c;从而提高软件测试的效率和准确性&#xff0c;维护软件的质量和稳定。如果在设计用例时没有遵循基本原则&#xff0c;这会影响用例的全面性、…

openGauss学习笔记-124 openGauss 数据库管理-设置账本数据库-查看账本历史操作记录

文章目录 openGauss学习笔记-124 openGauss 数据库管理-设置账本数据库-查看账本历史操作记录124.1 前提条件124.2 背景信息124.3 操作步骤 openGauss学习笔记-124 openGauss 数据库管理-设置账本数据库-查看账本历史操作记录 124.1 前提条件 系统中需要有审计管理员或者具有…

DevEco studio配置自己的虚拟环境

开始使用DevEco studio时使用的时华为预置的手机&#xff0c;通过网络访问&#xff0c;但是近期发现有两点问题 网络不稳定的时候机器很卡现在资源很难使用 DevEco提供了自定义环境的搭建&#xff0c;从而解决上面的问题 这里有几点问题需要硬盘至少10G空闲&#xff08;应该问题…

06 robotFrameWork+selenium2Library KiLL清理进程

1、新建bat文件&#xff1a;kill.bat 2、文件中添加&#xff1a; taskkill /F /IM IEDriverServer.exe taskkill /F /IM iexplore.exe taskkill /F /IM chrome.exe taskkill /F /IM chromedriver.exe 3、新建的关键字中&#xff0c;调用kill.bat OperatingSystem.Run ${CU…

调研了一下java常用的几个图片处理工具对Tiff文件的支持

ImageMagick 官网 https://imagemagick.org/&#xff0c; 支持多种格式。命令行工具很适合调试。功能很强大. 还有一款工具GraphicsMagick 是从ImageMagick的基础上研发出来的。 OpenCV 官网 https://opencv.org/ &#xff0c; github地址https://github.com/opencv/opencv&…

iOS WKWebView H5微信、支付宝支付跳转

iOS客户端实现嵌入H5进行支付跳转到客户端&#xff0c;支付完成后再跳转回自己的App时,解决WKWebView无法跳转回APP的BUG. 一、支付宝 - (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void…

如何挑选猫主食罐头?宠物店自用的5款猫主食罐头推荐!

临近双十二大促&#xff0c;是时候给家里的猫主子屯猫主食罐头了。许多铲屎官看大促的各种品牌宣传&#xff0c;看到眼花缭乱&#xff0c;不知道选哪些猫主食罐头好&#xff0c;胡乱选又怕踩坑。 猫罐头侠闪亮登场&#xff01;如何挑选猫主食罐头&#xff1f;作为经营宠物店7年…

AM驱动架构—优质Mini-LED显示技术解决方案

MiniLED背光驱动方案作为一种新兴的显示技术方案&#xff0c;具有更高的亮度、更广的色域范围和更低的功耗等优势&#xff1b;以其出色的性能和广泛的应用前景备受关注是实现MiniLED显示效果的重要环节。 MiniLED背光驱动方案是指通过控制MiniLED芯片的电流和亮度&#xff0c;…

教你如何优化MySQL慢查询SQL语句?快速提升系统性能!

前言 应用系统性能测试过程中&#xff0c;性能优化是绕不开的话题&#xff0c;对测试人员而言&#xff0c;性能优化的第一站就是SQL语句的优化与分析。因此本文主要以MySQL数据库为例&#xff0c;介绍常见的慢查询SQL语句执行效率分析与优化方法和简单示例&#xff0c;为致力于…

Avatar虚拟形象解决方案,趣味化的视频拍摄与直播新体验

企业们正在寻找新的方式来吸引和保持观众的注意力,一种新兴的解决方案就是使用Avatar虚拟形象技术&#xff0c;这种技术可以让用户在视频拍摄或直播场景中&#xff0c;以自定义的数字人形象出现&#xff0c;同时保持所有的表情和脸部驱动。美摄科技正是这个领域的领军者&#x…

漏电继电器 LLJ-250HT AC220V 50-500ma 面板安装

系列型号&#xff1a; LLJ-10H(S)漏电继电器LLJ-15H(S)漏电继电器LLJ-16H(S)漏电继电器 LLJ-25H(S)漏电继电器LLJ-30H(S)漏电继电器LLJ-32H(S)漏电继电器 LLJ-60H(S)漏电继电器LLJ-63H(S)漏电继电器LLJ-80H(S)漏电继电器 LLJ-100H(S)漏电继电器LLJ-120H(S)漏电继电器LLJ-125H(…

关于Java抽象类和接口的总结和一点个人的看法

꒰˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好&#xff0c;我是xiaoxie.希望你看完之后,有不足之处请多多谅解&#xff0c;让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ ა 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN 如需转载还请通知˶⍤⃝˶个人主页&am…

[sd_scripts]之train

https://github.com/kohya-ss/sd-scripts/blob/main/docs/train_README-zh.mdhttps://github.com/kohya-ss/sd-scripts/blob/main/docs/train_README-zh.md 支持模型fine-tune&#xff0c;dreambooth&#xff0c;lora&#xff0c;textual inversion。 1.数据准备 在任意多个…

图识单链表

CSDN主页&#xff1a;醋溜马桶圈_C语言进阶,初始C语言,数据结构-CSDN博客 Gitee主页&#xff1a;mnxcc (mnxcc) - Gitee.com 专栏&#xff1a;数据结构_醋溜马桶圈的博客-CSDN博客 我们之前学习了顺序表的有关知识&#xff0c;顺序表存在下面的问题&#xff1a; 尾插效率还不错…

C#多线程的操作

文章目录 1 使用线程意义2 C#线程开启的四种方式2.1 异步委托开启线程2.2 通过Thread类开启线程2.3 通过线程池开启线程2.4 通过任务Task开启线程 3 前台线程和后台线程简述3.1 前台线程3.2 后台线程 4 简述Thread和Task开启线程的区别4.1 Thread效果展示4.2 Task效果展示4.3 区…

2013年10月23日 Go生态洞察:字符串、字节、符文和字符

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

瑞吉外卖Day04

1.文件的上传下载 Value("${reggie.path}")private String basePath;/*** 文件上传** param file* return*/PostMapping("/upload")public R<String> upload(MultipartFile file) {log.info("文件上传");//原始文件名String originalFilen…

22款奔驰E260L升级原厂360全景影像 高清环绕的视野

360全景影像影像系统提升行车时的便利&#xff0c;不管是新手或是老司机都将是一个不错的配置&#xff0c;无论是在倒车&#xff0c;挪车以及拐弯转角的时候都能及时关注车辆所处的环境状况&#xff0c;避免盲区事故发生&#xff0c;提升行车出入安全性。 360全景影像包含&…

基于安卓android微信小程序的师生答疑交流平app

项目介绍 本课题研究的是基于HBuilder X系统平台的师生答疑交流APP&#xff0c;开发这款师生答疑交流APP主要是为了帮助用户可以不用约束时间与地点进行所需信息。本文详细讲述了师生答疑交流APP的界面设计及使用&#xff0c;主要包括界面的实现、控件的使用、界面的布局和异常…

macOS btop

brew install btop参考 5 个 htop 替代&#xff1a;增强你的 Linux 系统监控体验btop github