浅说树上倍增(下)

书接上文

树上倍增的具体实现

其实树上倍增大致可以分为三个步骤。

  1. dfs 预处理倍增数组设 d p [ x ] [ i ] dp[x][i] dp[x][i] 表示 x x x 点向上跳 2 i 2^i 2i 到达的点,初始值 d p [ x ] [ 0 ] dp[x][0] dp[x][0] 的值就为 x x x 的父亲节点的编号,在从根节点往下遍历的过程中,我们已经得到了该点上方所有点的倍增信息,可以得到状态转移方程:
    d p [ x ] [ i ] = d p [ d p [ x ] [ i − 1 ] [ i − 1 ] ; dp[x][i]=dp[dp[x][i-1][i-1]; dp[x][i]=dp[dp[x][i1][i1];
for (int j = 1; (1 << j) <= deep[x] - 1; j++) {dp[x][j] = dp[dp[x][j - 1]][j - 1];
}
  1. 调整两点深度对于深度不同的点,找最近公共祖先比较麻烦,所以我们先把两点的深度统一,即让深度较深的点跳到和深度较浅的点同一深度。具体跳跃方法可以参考差值的二进制数,比如 ( 10110 ) 2 (10110)_2 (10110)2 ,就需要向上跳 2 1 , 2 2 , 2 4 2^1,2^2,2^4 21,22,24。换言之就是,找当前数值中最大的 2 k 2^k 2k 的数,找到后再减去这个数,然后继续找。
if (deep[x] < deep[y]) swap(x, y);
int index = __lg(deep[x] - deep[y]);
for (int i = index; i >= 0; i--) {if (deep[dp[x][i]] >= deep[y])x = dp[x][i];if (deep[x] == deep[y])break;
}
  1. 找最近公共祖先对于深度相同的两点 u u u , v v v ,他们的最近公共祖先可能是任意一个点,那么如何跳跃呢?我们观察这个两个点的 d p dp dp 数组可以发现,在 i i i 比较大的时候, d p [ u ] [ i ] = d p [ v ] [ i ] dp[u][i]=dp[v][i] dp[u][i]=dp[v][i] ,说明此时已经跳到了最近公共祖先上方,我们需要找到 d p [ u ] [ i ] ! = d p [ v ] [ i ] dp[u][i]!=dp[v][i] dp[u][i]!=dp[v][i]
    由于我们也不知道i的具体值,所以只能一个一个尝试,当树的深度最大为 1 0 5 10^5 105 时, i i i 的最大值为17即可, i i i 的值和数据范围 有关,一般不会超过20,如果发现 d p [ u ] [ i ] = = d p [ v ] [ i ] dp[u][i]==dp[v][i] dp[u][i]==dp[v][i],则不动,否则就同时跳到 d p [ x ] [ i ] dp[x][i] dp[x][i] 这个点,由于一个数一定对应一个二进制数,所以最终一定会跳到最近公共祖先。
for (int j = 18; j >= 0; j--) {if (dp[x][j] == dp[y][j]) continue;x = dp[x][j], y = dp[y][j];
}
return dp[x][0];

Tips:
对于边权为1的树,找到两点的最近公共祖先后,通过两点的深度差相减就能得到答案。对于边权不为1的树,虽然也是通过深度差相减得到答案,但是要注意,如果 deep 数组中存储的是该点到根节点的距离,那么在树上倍增第二步操作中,把两个点移动到相同深度的操作就是错误的,这里的深度指的是离根节点经过的节点数量,不是离根节点的距离,所以对于有边权的树,我们需要重新开一个距离数组 dis ,而不能直接修改 deep 数组,这两个在该代码中的作用是不一样的。

小结

树上倍增经常用来求解需要找最近公共祖先的问题,同样,对于序列问题,很多时候还需要求极值,树上倍增也可以用来处理树上路径的极值。处理办法和倍增求区间极值有一点区别,因为对于树上的每一个点,有唯一的父亲节点,但是儿子节点有很多,没有办法记录祖先节点向下找 2 k 2^k 2k 这个区间内的答案。
那么如何求解 u u u 点到最近公共祖先 x x x 之间的极值呢?先维护一个极值的倍增数组, m a x [ x ] [ i ] max[x][i] max[x][i] 表示 x x x 点到 x x x 向上移动 2 i 2^i 2i 这个区间的极值,在 u u u 点往上跳的过程中,同时更新极值即可。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Chrome 132 版本新特性

Chrome 132 版本新特性 一、Chrome 132 版本浏览器更新 1. 在 iOS 上使用 Google Lens 搜索 在 Chrome 132 版本中&#xff0c;开始在所有平台上推出这一功能。 1.1. 更新版本&#xff1a; Chrome 126 在 ChromeOS、Linux、Mac、Windows 上&#xff1a;在 1% 的稳定版用户…

Kafka 日志存储 — 日志索引

每个日志分段文件对应两个索引文件&#xff1a;偏移量索引文件用来建立消息偏移量到物理地址之间的映射&#xff1b;时间戳索引文件根据指定的时间戳来查找对应的偏移量信息。 1 日志索引 Kafka的索引文件以稀疏索引的方式构造消息的索引。它并不保证每个消息在索引文件中都有…

消息队列篇--原理篇--RocketMQ(NameServer,Broker,单机上每秒处理数百万条消息性能)

1、概述 RocketMQ是阿里巴巴开源的一个分布式消息中间件&#xff0c;具有高吞吐量、低延迟和强一致性等特点。它特别适合大规模分布式系统的消息传递&#xff0c;广泛应用于电商、金融、物流等领域的实时数据处理和异步通信。 RocketMQ是用Java语言实现&#xff0c;在设计时参…

简述mysql 主从复制原理及其工作过程,配置一主两从并验证。

MySQL 主从同步是一种数据库复制技术&#xff0c;它通过将主服务器上的数据更改复制到一个或多个从服务器&#xff0c;实现数据的自动同步。 主从同步的核心原理是将主服务器上的二进制日志复制到从服务器&#xff0c;并在从服务器上执行这些日志中的操作。 MySQL主从同步是基…

Web前端开发技术之HTMLCSS知识点总结

学习路线 一、新闻网界面1. 代码示例2. 效果展示3. 知识点总结3.1 HTML标签和字符实体3.2 超链接、颜色描述与标题元素3.3 关于图片和视频标签&#xff1a;3.4 CSS引入方式3.5 CSS选择器优先级 二、flex布局1. 代码示例2. 效果展示3. 知识点总结3.1 span标签和flex容器的区别3.…

内存故障原因与诊断(Reasons and Diagnosis of Memory Failure)

内存故障原因与诊断 您是否曾遇到过电脑无法启动、黑屏、死机&#xff0c;或者系统卡顿的情况&#xff1f;这些问题看起来很复杂&#xff0c;实际上大多数都是内存故障引起的。内存是电脑的核心组成部分之一&#xff0c;任何小东西问题都可能导致系统死机&#xff0c;严重时甚…

vulnhub靶机(ReconForce)

一.信息收集: 使用nmap进行端口扫描,发现其开放了ftp,http,ssh服务 nmap -sS -O -sV -p- 192.168.80.142访问其80端口发现是一个网页,点击TroubleShoot后发现其需要登录 在去尝试使用ftp的匿名登录发现无法执行任何命令,发现了他的欢迎语有点特别 在扫描目录后没有发现什么有…

54,【4】BUUCTF WEB GYCTF2020Ezsqli

进入靶场 吓我一跳&#xff0c;但凡放个彭于晏我都不说啥了 提交个1看看 1 and 11 1# 还尝试了很多&#xff0c;不过都被过滤了&#xff0c;头疼 看看别人的WP 竟然要写代码去跑&#xff01;&#xff01;&#xff01;&#xff0c;不会啊&#xff0c;先用别人的代码吧&#xf…

vue2使用flv.js在浏览器打开flv格式视频

组件地址&#xff1a;GitHub - bilibili/flv.js: HTML5 FLV Player flv.js 仅支持 H.264 和 AAC/MP3 编码的 FLV 文件。如果视频文件使用了其他编码格式就打不开。 flv.vue <template><div><el-dialog :visible.sync"innerVisibleFlv" :close-on-pre…

Git原理与应用(三)【远程操作 | 理解分布式 | 推送拉取远程仓库 | 标签管理】

Git 理解分布式版本控制系统远程仓库新建远程仓库克隆远程仓库向远程仓库推送配置Git忽略特殊文件 标签管理理解标签创建标签操作标签删除标签 理解分布式版本控制系统 我们⽬前所说的所有内容&#xff08;工作区&#xff0c;暂存区&#xff0c;版本库等等&#xff09;&#x…

网络安全:信息时代的守护者

随着互联网的快速发展&#xff0c;网络安全问题日益成为全球关注的焦点。无论是个人用户、企业组织还是政府部门&#xff0c;网络安全都已成为保障信息安全、保护隐私、确保社会秩序的基石。在这个数字化时代&#xff0c;如何应对复杂多变的网络安全威胁&#xff0c;成为了我们…

BUUCTF_Web([GYCTF2020]Ezsqli)

1.输入1 &#xff0c;正常回显。 2.输入1 &#xff0c;报错false&#xff0c;为字符型注入&#xff0c;单引号闭合。 原因&#xff1a; https://mp.csdn.net/mp_blog/creation/editor/145170456 3.尝试查询字段&#xff0c;回显位置&#xff0c;数据库&#xff0c;都是这个。…

HTML知识点复习

1.src 和 href 的区别 src&#xff1a;表示对资源的引用&#xff0c; src指向的内容会嵌入到其标签里。 当浏览器解析到该元素时候&#xff0c;会暂停其他资源的下载和处理&#xff0c; 直到将该资源加载、编译、执行完毕&#xff0c;所以js脚本一般会放在页面底部 href&…

Windows11电脑总是一闪一闪的,黑一下亮一些怎么解决

Windows11电脑总是一闪一闪的&#xff0c;黑一下亮一些怎么解决 1. 打开设备管理器2. 点击显示适配器3. 更新下方两个选项的驱动3.1 更新驱动Inter(R) UHD Graphixs3.2 更新驱动NVIDIA GeForce RTX 4060 Laptop GPU 4. 其他文章快来试试吧&#x1f970; 1. 打开设备管理器 在电…

WPS计算机二级•高效操作技巧

听说这里是目录哦 斜线表头 展示项目名称&#x1f34b;‍&#x1f7e9;横排转竖排&#x1f350;批量删除表格空白行&#x1f348;方法一方法二建辅助列找空值 能量站&#x1f61a; 斜线表头 展示项目名称&#x1f34b;‍&#x1f7e9; 选中单元格&#xff0c;单击右键➡️“设…

使用Torchvision框架实现对象检测:从Faster-RCNN模型到自定义数据集,训练模型,完成目标检测任务。

引言 对象检测是一项计算机视觉中的核心任务&#xff0c;其目标是识别图像中的目标并标记它们的位置和类别。在Pytorch生态系统中&#xff0c;Torchvision提供了多种预训练的对象检测模型&#xff08;如Faster-RCNN、Mask-RCNN等&#xff09;&#xff0c;为开发者快速构建应用…

SSM课设-学生管理系统

【课设者】SSM课设-学生管理系统 技术栈: 后端: SpringSpringMVCMybatisMySQLJSP 前端: HtmlCssJavaScriptEasyUIAjax 功能: 学生端: 登陆 学生信息管理 个人信息管理 老师端: 多了教师信息管理 管理员端: 多了班级信息管理 多了年级信息管理 多了系统用户管理

C语言之装甲车库车辆动态监控辅助记录系统

&#x1f31f; 嗨&#xff0c;我是LucianaiB&#xff01; &#x1f30d; 总有人间一两风&#xff0c;填我十万八千梦。 &#x1f680; 路漫漫其修远兮&#xff0c;吾将上下而求索。 C语言之装甲车库车辆动态监控辅助记录系统 目录 一、前言 1.1 &#xff08;一&#xff09;…

【STM32-学习笔记-4-】PWM、输入捕获(PWMI)

文章目录 1、PWMPWM配置 2、输入捕获配置3、编码器 1、PWM PWM配置 配置时基单元配置输出比较单元配置输出PWM波的端口 #include "stm32f10x.h" // Device headervoid PWM_Init(void) { //**配置输出PWM波的端口**********************************…

Kinova仿生机械臂Gen3搭载BOTA 力矩传感器SeneOne:彰显机器人触觉 AI 与六维力传感的融合力量

随着工业4.0时代的到来&#xff0c;自动化和智能化成为制造业的趋势。机器人作为实现这一趋势的重要工具&#xff0c;其性能和智能水平直接影响到生产效率和产品质量。然而&#xff0c;传统的机器人系统在应对复杂任务时往往缺乏足够的灵活性和适应性。为了解决这一问题&#x…