RMQ(Range Minimum/Maximum Query),即区间最值查询

查询很多的时候求[l,r]的最大值可以弄一个数组f[i,j]表示i~j的最大值

//这个是线段树

rmq是f[i,j]表示   i 到 i+2^j-1 这个区间的最大值

/*给例子好理解

 比如f[i,0]  =  a[i]  然后先要预处理这个f  方法是DP
 f[i,j] = max( f[i,j-1] , f[ i + (1<<j-1) , j-1] )
相当于是二分
比如  2,4其实是2,18
那么 2~ 18 中间有16个数
我们求2~18的最值等于 2~10 和 11~18的最值的
最值用 rmq表示就是f[2,3]
初始化条件就是f[i,0]=a[i]
有了初始化有了动态转移方程就可以得到f了
现在假设来了一个请求 l~r
那么我们先要得到一个区间的大小就是r-l+1
找到一个K
这个K是 2^K<=r-l+1 的最大的K
然后就是ans=  max( f[l,k], f[r-(1<<k)+1,k])
假设是2~20区间长度是19K=4
就是 f[2,4]  f[4,4]
换成线段树的表示就是
f[2,18] f[4,20]
这2段的最值就是f[2,20]的最值了
虽然有重复的部分 但是不影响
*/
 
 
 

LCA(最近公共祖先)
 
LCA就是把问题转化为RMQ
转化过程如下:
一棵树,我们对它先进行DFS,记录下路径
比如上图的这颗树(图来自百度,侵删)
DFS的结果是1 3 1 2 4 2 5 6 5 7
深度就是1 2 1 2 3 2 3 4 3 4
仔细想想会得到求 i~j 的路径就是上面那个路径的子集 
//其实这个路径没写完整 后面还有1 3 1 2 4 2 5 6 5 7 5 2 1
 
 
记录深度和路径以及每一个节点第一次到达的时候一共走了几步
 //对于1 2 3 4 5 6 7来说 他们分别是1 4 2 5 7 8 10
然后问题要求是求路径
比如求4 ~7  查一下
4第一次出现是5
7第一次出现是10
那么问题就是求1 3 1 2 4 2 5 6 5 7 5 2 1这个里面的第五个到第十个4 2 5 6 5 7
深度对应的是这6个数字 3 2 3 4 3 4
深度最小的那个就是他们的公共父节点
深度为2的那个路径上的2
问题就变成了求区间
假设:

路径是path[] 深度是dep[] 首次出现是first[]
求i~j就变成了f [ dep [ first[ i ] ] , dep [ first[ j ] ] ]

假设结果是 __min
在这段区间上搜索一下
if f[i]= __ min
那么保存i
公共父节点就是 path [ i ]
 

RMQ和LCA的更多相关文章

  1. 【RMQ】洛谷P3379 RMQ求LCA

    题目描述 如题,给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先. 输入输出格式 输入格式: 第一行包含三个正整数N.M.S,分别表示树的结点个数.询问的个数和树根结点的序号. 接下来N-1行每 ...

  2. RMQ求LCA

    题目链接 rmq求LCA,interesting. 一直没有学这玩意儿是因为CTSC的Day1T2,当时我打的树剖LCA 65分,gxb打的rmq LCA 45分... 不过rmq理论复杂度还是小一点 ...

  3. BZOJ1906树上的蚂蚁&BZOJ3700发展城市——RMQ求LCA+树链的交

    题目描述 众所周知,Hzwer学长是一名高富帅,他打算投入巨资发展一些小城市. Hzwer打算在城市中开N个宾馆,由于Hzwer非常壕,所以宾馆必须建在空中,但是这样就必须建立宾馆之间的连接通道.机智 ...

  4. poj 1330 Nearest Common Ancestors(LCA 基于二分搜索+st&rmq的LCA)

    Nearest Common Ancestors Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 30147   Accept ...

  5. dfs序+RMQ求LCA详解

    首先安利自己倍增求LCA的博客,前置(算不上)知识在此. LCA有3种求法:倍增求lca(上面qwq),树链剖分求lca(什么时候会了树链剖分再说.),还有,标题. 是的你也来和我一起学习这个了qwq ...

  6. 数据结构 《18》----RMQ 与 LCA 的等价性 (一)

    前言     RMQ: 数组 a0, a1, a2,..., an-1, 中求随意区间 a[i+1], a[i+2], ..., a[i+k] 的最小值     LCA: 求二叉树中两个节点的最低公共 ...

  7. LOJ#137. 最小瓶颈路 加强版(Kruskal重构树 rmq求LCA)

    题意 三倍经验哇咔咔 #137. 最小瓶颈路 加强版 #6021. 「from CommonAnts」寻找 LCR #136. 最小瓶颈路 Sol 首先可以证明,两点之间边权最大值最小的路径一定是在最 ...

  8. hdu 2586 欧拉序+rmq 求lca

    题意:求树上任意两点的距离 先说下欧拉序 对这颗树来说 欧拉序为 ABDBEGBACFHFCA 那欧拉序有啥用 这里先说第一个作用 求lca 对于一个欧拉序列,我们要求的两个点在欧拉序中的第一个位置之 ...

  9. st表、RMQ和LCA

    int lca(int x,int y) { if(de[x]<de[y]) swap(x,y); int d=de[x]-de[y]; for(int i=log2(d);i>=0;i- ...

随机推荐

  1. 基础学习总结(四)--SQLite

    1. SQLiteDatabase   操作SQLite数据库的类.可以执行SQL语句,对数据库进行增.删.查.改的操作.也可以进行transaction的控制.很多类对数据库的操作最终都是通过SQL ...

  2. C# 条码标签打印程序,RDLC报表动态显示多条码标签的方法

    初学c#,因最近公司客户要求原出货标签需实现条码化,练手的机会来了,遂动手做这个程序,开始都是一些增删改查操作一直很顺利,但到RDLC报表将条码显示到报表上犯难了,因为初学未接触过报表,上网查资料均一 ...

  3. RGB颜色二值化

    原理:RGB颜色根据计算'灰度'的公式,可以转化为黑白2种颜色,实现二值化. 业务场景的应用:可以根据背景颜色,取一个黑色或白色的颜色,作为背景色上的文案字体颜色 具体代码: function get ...

  4. Eclipse导入android包错误

    错误提示:Invalid project description… 解决方案:假设你的工作空间是workshop,那么你可以在你的workshop下新建一个文件夹,然后放入你的包,再在Eclipse中 ...

  5. ORACLE 11G 配置DG 报ORA-10458、ORA-01152、ORA-01110

    操作系统: Oracle Linux Server release 5.7 数据库版本: Oracle Database 11g Enterprise Edition Release 11.2.0.3 ...

  6. 项目文件包含 ToolsVersion="12.0" 设置,而此版本的 MSBuild 不支持该工具版本

    解决方法: 右键点击你的项目,选择属性,再点击配置属性中的常规,常规中有个平台工作集,把V120改成V100,点击应用即可.

  7. TypeError: Object #<IncomingMessage> has no method 'flash'

    JavaScript相关代码: router.post('/reg', function(req, res) { //检验用户两次输入的口令是否一致 if (req.body['password-re ...

  8. python学习小结5:封装、继承、多态

    面向对象程序设计中的类有三大特性: 继承,封装,多态 继承:以普通的类为基础建立专门的类对象 封装:对外部世界隐藏对象的工作细节 多态:可对不同类的对象使用同样的操作 在Python中类的继承定义基本 ...

  9. Javascript 面向对象编程

    Javascript是一个类C的语言,他的面向对象的东西相对于C++/Java比较奇怪,但是其的确相当的强大,在 Todd 同学的“对象的消息模型”一文中我们已经可以看到一些端倪了.这两天有个前同事总 ...

  10. Pentaho Data Integration笔记 (一):安装

    介绍 Pentaho Data Integration (PDI) is an extract, transform, and load (ETL) solution that uses an inn ...