news 2026/6/22 22:38:13

PAT 1151 LCA in a Binary Tree

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
PAT 1151 LCA in a Binary Tree



这一题的大意是给出一个BST的前序遍历,让我们在这棵BST二叉树中,给出两个的点,判断这两个点在这棵二叉树的最近公共祖先是谁,这两个点可能并不在树中,也有可能给出的节点是另一个节点的祖先,我们需要针对不同情况,做出不同的判断。
因为题目给出的节点的值是在int范围内,也就是说这个值可能会很大,我们可以选择离散化,把N个值映射到1-N,这样我们就可以用int depp[10005]直接来表示某一个节点的深度了。与unordered_map<int,int>来说速度更快了,因为是BST,所以中序遍历的节点就是将所有值从小到大排序的结果。实际上不用离散化也可以吧,
可以参考这一题:

PAT 1151 LCA in a Binary Tree

但BST中序遍历是升序的,用离散化也可以在建树的过程中少写一个for循环查找中序遍历中根节点的位置。
我们可以根据中序遍历和前序遍历来建树,用哈希表来存储节点,从而可以来找任意两个节点的公共祖先。
因为只需要找公共祖先,所以我们不用存储孩子节点,只需要找到每一个节点的父亲节点,和它的深度即可。
根据前序遍历和中序遍历的建树方法已经写过多次了,这里不再赘述,在建好树后,我们就需要关注如何找两个节点的最近公共祖先。
我们只需要保证当深度相同时,两个节点都去看它的父亲节点,如果一个节点的深度比另一个节点大,那么我们先去看这个深度深的节点,同时看深度深的节点的祖先节点是否会等于另一个节点。 直到两个节点深度一样。
大致思路就是如上
完整代码如下:

#include<bits/stdc++.h>#include<iostream>usingnamespacestd;intM;intN;unordered_map<int,int>parent;vector<int>preorder;vector<int>inorder;vector<int>temp;unordered_map<int,int>last;intdeep[10005];unordered_map<int,int>mp;intbuild(intprestart,intpreend,intinstart,intinend,intd){if(prestart>preend||instart>inend){return-1;}introot=preorder[prestart];deep[root]=d;intindex=root-1;intlen=index-instart;intxl=build(prestart+1,prestart+len,instart,instart+len-1,d+1);if(xl!=-1)parent[xl]=root;intxr=build(prestart+len+1,preend,instart+len+1,inend,d+1);if(xr!=-1)parent[xr]=root;returnroot;}intmain(){cin>>M>>N;for(inti=0;i<N;i++){intx;cin>>x;preorder.push_back(x);}temp=preorder;sort(temp.begin(),temp.end());for(inti=0;i<temp.size();i++){mp[temp[i]]=i+1;last[i+1]=temp[i];temp[i]=i+1;}inorder=temp;for(inti=0;i<preorder.size();i++){preorder[i]=mp[preorder[i]];}introot=build(0,N-1,0,N-1,0);intu;intv;for(inti=0;i<M;i++){cin>>u>>v;if(!mp.count(u)&&!mp.count(v)){//如果u和v都不存在printf("ERROR: %d and %d are not found.\n",u,v);continue;}elseif(!mp.count(u)){printf("ERROR: %d is not found.\n",u);continue;}elseif(!mp.count(v)){printf("ERROR: %d is not found.\n",v);continue;}//现在要找最近公共祖先了//先把u,v离散//如果它们不再同一层,那么就需要把它们放到同一层inttempu=mp[u];inttempv=mp[v];if(tempu==tempv){printf("%d is an ancestor of %d.\n",u,v);continue;}boolflag=0;while(tempu!=root||tempv!=root){if(deep[tempu]>deep[tempv]){if(parent[tempu]==tempv){//说明v是u的ancestorflag=1;printf("%d is an ancestor of %d.\n",v,u);break;}tempu=parent[tempu];}elseif(deep[tempu]==deep[tempv]){if(parent[tempu]==parent[tempv]){flag=1;printf("LCA of %d and %d is %d.\n",u,v,last[parent[tempu]]);break;}tempu=parent[tempu];tempv=parent[tempv];}else{if(parent[tempv]==tempu){//说明u是v的ancestorflag=1;printf("%d is an ancestor of %d.\n",u,v);break;}tempv=parent[tempv];}}if(flag==0){printf("LCA of %d and %d is %d.\n",u,v,last[parent[tempu]]);}}return0;}

注意,给出的两个节点可能是同一个,我们要进行特判。

inttempu=mp[u];inttempv=mp[v];if(tempu==tempv){printf("%d is an ancestor of %d.\n",u,v);continue;}

总结:这一题就是BST建树+最近公共祖先的求法,我们用根据实际情况灵活建树。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 14:47:55

汽车变速器电控系统Simulink模型:从原理到实现

汽车变速器电控系统 Simulink 模型 汽车动力换挡变速器电控系统 变速器电控系统仿真 汽车/车辆电子课设设计该模型根据汽车动力换挡变速器的工作原理&#xff0c;设计出液压执行机构&#xff0c;确定控制器&#xff0c;制定汽车动力换挡变速器电控系统总体方案以及电控系统开发…

作者头像 李华
网站建设 2026/6/23 19:28:35

Atmosphere自定义固件终极指南:从安装到故障排除

Atmosphere自定义固件终极指南&#xff1a;从安装到故障排除 【免费下载链接】Atmosphere Atmosphre is a work-in-progress customized firmware for the Nintendo Switch. 项目地址: https://gitcode.com/GitHub_Trending/at/Atmosphere Atmosphre是专为Nintendo Swit…

作者头像 李华
网站建设 2026/6/23 1:56:40

docker网络模式详解

docker网络模式 #怎么进行查看Docker的网络模式 命令&#xff1a;Docker network ls 查看有几种网络模型docker inspect 容器名字 可以查看到容器的具体信息包含网络信息怎么在创建容器的时候指定使用的网络模式 --net网络模式默认是使用的bridge桥接模式bridge模式&#xf…

作者头像 李华
网站建设 2026/6/23 19:30:57

永磁同步电机基于非线性磁链观测器的转子位置估计策略:SCI一区顶刊复现与SIMULINK仿真

永磁同步电机基于非线性磁链观测器的转子位置估计策略&#xff0c;利用非线性磁链观测器进行无位置传感器控制&#xff0c;SCI一区顶刊复现&#xff0c;SIMULINK仿真无位置传感器控制这玩意儿在电机控制圈子里算是经久不衰的热点了。今天咱们来唠唠基于非线性磁链观测器的转子位…

作者头像 李华
网站建设 2026/6/23 19:30:48

异步电机直接转矩控制算法模型在R2016b版本及以上的正常运行

异步电机直接转矩控制算法模型正常运行R2016b版本及以上均可运异步电机直接转矩控制&#xff08;DTC&#xff09;的仿真模型在电机控制圈子里就像深夜大排档的烧烤师傅——看着粗犷但手里有真功夫。今天咱们拆解的这个模型用着Matlab/Simulink平台&#xff0c;核心是那个能实时…

作者头像 李华
网站建设 2026/6/23 19:35:48

从前端体验到后端架构:Airbnb全栈SDET面试深度解析

在当今快速迭代的互联网行业&#xff0c;全栈软件测试开发工程师&#xff08;Full Stack SDET&#xff09;已成为保障产品质量的关键角色。以Airbnb这样全球领先的旅行服务平台为例&#xff0c;其产品横跨Web、移动端及复杂的微服务架构&#xff0c;对SDET的要求已远远超越传统…

作者头像 李华