当前位置: 首页 > news >正文

算法竞赛备考冲刺必刷题(C++) | 洛谷 P3379 【模板】最近公共祖先(LCA)

本文分享的必刷题目是从蓝桥云课洛谷AcWing等知名刷题平台精心挑选而来,并结合各平台提供的算法标签和难度等级进行了系统分类。题目涵盖了从基础到进阶的多种算法和数据结构,旨在为不同阶段的编程学习者提供一条清晰、平稳的学习提升路径。

欢迎大家订阅我的专栏:算法题解:C++与Python实现!

附上汇总贴:算法竞赛备考冲刺必刷题(C++) | 汇总


【题目来源】

洛谷:P3379 【模板】最近公共祖先(LCA) - 洛谷

【题目描述】

如题,给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先。

【输入】

第一行包含三个正整数N , M , S N,M,SN,M,S,分别表示树的结点个数、询问的个数和树根结点的序号。

接下来N − 1 N-1N1行每行包含两个正整数x , y x, yx,y,表示x xx结点和y yy结点之间有一条直接连接的边(数据保证可以构成树)。

接下来M MM行每行包含两个正整数a , b a, ba,b,表示询问a aa结点和b bb结点的最近公共祖先。

【输出】

输出包含M MM行,每行包含一个正整数,依次为每一个询问的结果。

【输入样例】

5 5 4 3 1 2 4 5 1 1 4 2 4 3 2 3 5 1 2 4 5

【输出样例】

4 4 1 4 4

【算法标签】

《洛谷 P3379 最近公共祖先(LCA)》 #最近公共祖先LCA# #模板题# #O2优化#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=500005;intn,m,s,a,b;// n: 节点数,m: 查询数,s: 根节点vector<int>e[N];// 邻接表存储树intdep[N];// 节点的深度intfa[N][20];// 倍增祖先表,fa[u][i]表示u的2^i级祖先// 深度优先搜索,预处理深度和祖先表voiddfs(intu,intfather){// 计算当前节点的深度dep[u]=dep[father]+1;// 初始化直接父节点fa[u][0]=father;// 预处理倍增祖先表for(inti=1;i<=19;i++)fa[u][i]=fa[fa[u][i-1]][i-1];// 遍历子节点for(intv:e[u])if(v!=father)// 避免走回父节点dfs(v,u);}// 求两个节点的最近公共祖先intlca(intu,intv){// 第一步:将u和v调整到同一深度if(dep[u]<dep[v])swap(u,v);// 将u向上跳,直到与v同深度for(inti=19;i>=0;i--)if(dep[fa[u][i]]>=dep[v])u=fa[u][i];// 如果此时u==v,说明v是u的祖先if(u==v)returnv;// 第二步:u和v同时向上跳for(inti=19;i>=0;i--)if(fa[u][i]!=fa[v][i])// 如果祖先不同,就一起向上跳u=fa[u][i],v=fa[v][i];// 此时u和v的父节点就是LCAreturnfa[u][0];}intmain(){// 输入树的信息cin>>n>>m>>s;// 读入n-1条边for(inti=1;i<n;i++){intx,y;cin>>x>>y;e[x].push_back(y);e[y].push_back(x);}// 从根节点s开始DFS,预处理深度和祖先表dfs(s,0);// 处理m个查询for(inti=1;i<=m;i++){inta,b;cin>>a>>b;cout<<lca(a,b)<<endl;// 输出LCA}return0;}

【运行结果】

5 5 4 3 1 2 4 5 1 1 4 2 4 4 3 2 4 3 5 1 1 2 4 4 5 4
http://www.jsqmd.com/news/172074/

相关文章:

  • 2025年终麻将机品牌推荐:五大主流品牌性能与服务实力深度评测 - 速递信息
  • 数电学习笔记
  • RTMP推流平台EasyDSS无人机推流直播技术在交通视频监测场景的智能应用
  • PHP与MQTT协议融合实践,构建低功耗智能控制系统的终极指南
  • 国产化替代中的关键一环:数字孪生云渲染技术发展趋势与生态构建
  • 工业PLC数据采集难题,PHP如何实现高效解析与零延迟上传?
  • AT arc114C - Sequence Scores
  • 格栅板制造厂哪家技术强?格栅板厂家哪家好? - 工业推荐榜
  • Java计算机毕设之基于SpringBoot生鲜商城系统设计与实现基于Springboot网上生鲜销售商城网站设计与实现(完整前后端代码+说明文档+LW,调试定制等)
  • golang程序的coredump如何查看?
  • Java毕设项目:基于SpringBoot生鲜商城系统设计与实现(源码+文档,讲解、调试运行,定制等)
  • 从数据中心的GPU到用户屏幕:实时云渲染如何打通技术链路?
  • 2025年上海做得好的家装厂家哪家强,家居全屋定制/法式大平层设计/轻奢室内设计/复古室内空间设计,家装厂家哪家强 - 品牌推荐师
  • YOLOv8支持多语言界面吗?国际化进展通报
  • YOLOv8能否检测圆形物体?特殊形状适应性测试
  • YOLOv8 CUDA初始化失败?NVIDIA驱动检查清单
  • 年货零食囤货清单与新年礼包家庭装:旺旺大礼包以健康心意重塑春节消费 - 速递信息
  • 3D数字人骨骼觉醒:腾讯混元开源十亿参数3D人体动作生成新SOTA
  • 2025年液压/立式/全自动/卧式/废纸板打包机厂家实力推荐榜:技术领先与市场口碑双优之选 - 品牌推荐官
  • 仅限本周!PHP实现设备指令秒级响应的6种黑科技方法首次披露
  • 【PHP WebSocket优化终极指南】:掌握实时通信性能提升的5大核心技术
  • 适合送小朋友的零食礼包:旺旺大礼包如何成为 2026 春节精准放心之选 - 速递信息
  • 2025-2026 选滴丸机,烟台百药泰为何成为优选? - 品牌推荐大师
  • 企业微信 API 深度实战:外部群主动推送消息的“硬核”指南
  • YOLOv8与Cortex长期指标存储系统集成方案
  • PHP实时数据处理架构设计(工业级稳定性保障方案)
  • 基于主成分分析和BP神经网络(PCA-BP)的手写字母识别的Matlab代码
  • 2026新年限定零食礼包推荐:旺旺大礼包以 “专属仪式感” 定义春节社交新礼遇 - 速递信息
  • 值得收藏多智能体系统完全指南:从概念到实践,提升AI应用效率
  • 企业微信 API 深度实战:外部群消息主动推送的“避坑”逻辑与架构实现