线段树合并三十天:从入门到放弃

2023-10-20 11:10

本文主要是介绍线段树合并三十天:从入门到放弃,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

线段树合并

  • 前言
  • 一、前置知识
  • 二、线段树合并简介
  • 三、时间复杂度
  • 四、用处
  • 五、例题

前言

由于各种原因,我的博客已经有一个月没有更新了。今天,我来写一片博客:能把你弄崩溃的 线段树合并 \Huge\color{red}\text{线段树合并} 线段树合并

一、前置知识

  • 动态开点线段树
  • 权值线段树

如果不会的我没法帮你

二、线段树合并简介

线段树合并,就是建立一棵新的线段树保存原有的两颗线段树的信息。

图片来源于某人的线段树合并讲义

一波凌云踏步再加一个托马斯回旋非常漂亮!

但是!咋做呢?

别急,我来给你讲讲看

  1. 如果a有pos位置,b没有,那么新的线段树pos位置赋成a,返回
  2. 如果b有pos位置,a没有,赋成b,返回
  3. 如果此时已经合并到两棵线段树的叶子节点了,就把b在pos的值加到a上,把新线段树上的pos位置赋成a
  4. 递归处理左子树
  5. 递归处理右子树
  6. 用左右子树的值更新当前节点
  7. 将新线段树上的pos位置赋成a

是不是很懵逼?别急,我来给你一个example:

假设一个线段树为:

1
2
3
4
NULL

而另一个线段树为

1
2
NULL
3
4

则他们合并起来则是:

2
4
3
7
4

代码:

int merge(int a,int b,int l,int r)
{if(!a) return b;if(!b) return a;if(l==r){return a;}int mid=(l+r)>>1;tr[a].l=merge(tr[a].l,tr[b].l,l,mid);tr[a].r=merge(tr[a].r,tr[b].r,mid+1,r);push_up(a);return a;
}

妙啊!

三、时间复杂度

我最害怕的就是计算时间复杂度惹!
——某位巨佬

关于时间复杂度好不好算,有一个公式:

【数据删除】(我不会

不过可以看这位dalao的blog

首先我们需要知道动态开点线段树中插入一个点会加入多少个新的节点?
线段树从顶端到任意一个叶子结点之间有 log ⁡ n \log n logn层,每层最多新增一个节点。
所以插入一个新的点复杂度是 log ⁡ n \log n logn的。

两棵线段树合并的复杂度显然取决于两棵线段树重合的叶子节点个数,假设有 m m m个重合的点,这两棵线段树合并的复杂度就是 m log ⁡ n m\log n mlogn了,所以说,如果要合并两棵满满的线段树,这个复杂度绝对是远大于 log ⁡ n \log n logn级别的。
也就是说,千万不要以为线段树合并对于任何情况都是 log ⁡ n \log n logn的!

别崩溃,因为它一均摊, 1 0 5 10^5 105至少能过

四、用处

这玩意有啥用呢?这个玩意可以处理一些用其他数据结构不好处理的子树问题
你对每个点开一棵线段树然后能维护的东西,线段树合并都能维护,因为他们的本质是一样的。

五、例题

CF600E

大意:

给你一棵有 n n n个点的树 n ≤ 1 0 5 n\leq10^5 n105,树上每个节点都有一种颜色 c i , c i ≤ n c_i,c_i\leq n ci,cin,让你求每个点子树出现最多的颜色/编号的和

洛谷P4556

洛谷P3224

洛谷P1600

CF666E

这篇关于线段树合并三十天:从入门到放弃的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/246709

相关文章

基于Python实现进阶版PDF合并/拆分工具

《基于Python实现进阶版PDF合并/拆分工具》在数字化时代,PDF文件已成为日常工作和学习中不可或缺的一部分,本文将详细介绍一款简单易用的PDF工具,帮助用户轻松完成PDF文件的合并与拆分操作... 目录工具概述环境准备界面说明合并PDF文件拆分PDF文件高级技巧常见问题完整源代码总结在数字化时代,PD

Python实现Word转PDF全攻略(从入门到实战)

《Python实现Word转PDF全攻略(从入门到实战)》在数字化办公场景中,Word文档的跨平台兼容性始终是个难题,而PDF格式凭借所见即所得的特性,已成为文档分发和归档的标准格式,下面小编就来和大... 目录一、为什么需要python处理Word转PDF?二、主流转换方案对比三、五套实战方案详解方案1:

pandas数据的合并concat()和merge()方式

《pandas数据的合并concat()和merge()方式》Pandas中concat沿轴合并数据框(行或列),merge基于键连接(内/外/左/右),concat用于纵向或横向拼接,merge用于... 目录concat() 轴向连接合并(1) join='outer',axis=0(2)join='o

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

从入门到进阶讲解Python自动化Playwright实战指南

《从入门到进阶讲解Python自动化Playwright实战指南》Playwright是针对Python语言的纯自动化工具,它可以通过单个API自动执行Chromium,Firefox和WebKit... 目录Playwright 简介核心优势安装步骤观点与案例结合Playwright 核心功能从零开始学习

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat