news 2026/4/22 20:55:29

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法竞赛备考冲刺必刷题(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
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/21 13:45:52

YOLOv8与Cortex长期指标存储系统集成方案

YOLOv8与Cortex长期指标存储系统集成方案 在智能制造工厂的视觉质检线上&#xff0c;一台搭载YOLOv8模型的边缘设备正以每秒30帧的速度检测电路板缺陷。突然&#xff0c;推理延迟从80ms缓慢攀升至220ms——这个变化在实时监控中几乎不可察觉&#xff0c;但持续一周后导致了数千…

作者头像 李华
网站建设 2026/4/18 0:05:45

一文搞懂YOLOv8模型结构及其在COCO数据集上的应用

YOLOv8 模型结构与 COCO 数据集应用全解析 在智能摄像头越来越“看得懂”世界的今天&#xff0c;背后支撑它们视觉能力的&#xff0c;往往是像 YOLOv8 这样的高效目标检测模型。从自动驾驶车辆识别行人&#xff0c;到工厂流水线上自动检出缺陷产品&#xff0c;再到手机相册中自…

作者头像 李华
网站建设 2026/4/18 13:18:20

YOLOv8模型导出为ONNX格式教程:便于生产环境部署

YOLOv8模型导出为ONNX格式教程&#xff1a;便于生产环境部署 在工业质检、智能安防乃至自动驾驶的边缘计算场景中&#xff0c;一个训练好的目标检测模型能否快速、稳定地部署到非GPU服务器或嵌入式设备上&#xff0c;往往决定了项目的成败。尽管PyTorch提供了强大的训练能力&a…

作者头像 李华
网站建设 2026/4/18 1:07:02

YOLOv8推理延迟优化:TensorRT加速方案初探

YOLOv8推理延迟优化&#xff1a;TensorRT加速方案初探 在自动驾驶的感知系统中&#xff0c;每毫秒都至关重要——当车辆以60公里时速行驶时&#xff0c;100毫秒的延迟就意味着前进1.67米。而在这条时间链上&#xff0c;目标检测模型的推理耗时往往是关键瓶颈之一。即便像YOLOv8…

作者头像 李华
网站建设 2026/4/18 1:48:41

值得收藏多智能体系统完全指南:从概念到实践,提升AI应用效率

文章介绍了多智能体系统的概念&#xff0c;即将复杂应用拆分为多个协同工作的专业化智能体。多智能体系统在三种场景下特别有用&#xff1a;当单个智能体的上下文或记忆过大时、分布式开发环境以及需要并行执行子任务时。多智能体模式支持"多跳multi-hop"特性&#x…

作者头像 李华
网站建设 2026/4/18 16:24:39

C#快速开发避坑指南,资深工程师绝不告诉你的5个系统设计陷阱

第一章&#xff1a;C#快速开发中的认知重构在现代软件开发中&#xff0c;C# 作为一门兼具高性能与高生产力的语言&#xff0c;正在经历从传统面向对象思维向现代化快速开发范式的转变。开发者需要重新审视编码习惯、架构选择和工具链集成方式&#xff0c;以充分发挥 .NET 平台的…

作者头像 李华