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. Node.js学习资料整理

    了解node,node主要能干啥? Node.js究竟是什么?:http://www.ibm.com/developerworks/cn/opensource/os-nodejs/ nodejs教程: ...

  2. Javascript原型链

    原型链的关系 在Javascript中,只要创建了一个新函数,就会为该函数创建prototype属性,指向函数的原型对象,Object.prototype是所有对象最顶层的原型.所有对象都继承由Obj ...

  3. Entity Framework 并发处理借鉴

    如下博客 http://www.cnblogs.com/Bce-/p/3725868.html

  4. net.sf.json.JSONException: java.lang.NoSuchMethodException

    在尝试将json对象转换为list时候出现了如下错误 Exception in thread "main" net.sf.json.JSONException: java.lang ...

  5. MySQL 多实例数据库还原脚本-备份集与端口对应

    版本:5.5.14 OS: ConetOS 6.3 1.创建recover.sh [root@yoon  export]# vi  recover.sh #!/bin/bash bakdir=/exp ...

  6. Android 中的WiFi剖析

    Android的WiFi 我们通常看到WiFi的守护进程wpa_supplicant在我们的ps的进程列表中,这个就是我们的wifi守护进程.wpa_supplicant在external/wpa_s ...

  7. dblink 的源数据表结构修改后在存储过程里执行报错

    原情况:A服务器表A服务器B也有一张表A服务器B上有一个存储过程要把本地的head表向A服务器表里插入数据.变更后:在A服务器表里增加了一个字段inserttime,服务器B存储过程本地表向A服务器插 ...

  8. oracle 外部表

    CREATE TABLE "EXT_ENTRY_WORKFLOW" ( ), ), "CREATE_DATE" DATE, ), ), ), ), ), ), ...

  9. Team Homework #3

    我们组采访了以下几组学长学姐.因为隐私问题我们不会写出他们的个人信息. 1:平均每周所花时间:10:平均写的代码总数:2000:最有用的部分:锻炼团队合作精神:最没用的部分:写博客:改进:完全不需要博 ...

  10. 阿里云服务器上安装mysql的心路历程(博友们进来看看哦)

    在阿里云花了100买了一台云服务器,配置如下: CPU: 1核 内存: 512MB 数据盘: 0G 带宽: 1Mbps 阿里云服务器安装mysql搞得我想吐血,搞了一个多星期,现在才搞好,而且,还有许 ...