python使用广度优先搜索算法求解二叉树堂兄弟节点问题

本文主要是介绍python使用广度优先搜索算法求解二叉树堂兄弟节点问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

如果给定一颗二叉树,同时给定这颗二叉树中的两个不同节点的值,这里要注意二叉树中的各个节点的值是唯一的,对这两个树节点进行判断是否是堂兄弟节点,堂兄弟节点的意思是处在同一个层级,但是两个节点各有不同的父节点。

添加图片注释,不超过 140 字(可选)

如上图给定的二叉树,对其中的两个节点node1节点是9,node2节点是8,判断这颗树种的这两个节点是否是堂兄弟节点,这里返回的结果是False

添加图片注释,不超过 140 字(可选)

添加图片注释,不超过 140 字(可选)

再给定如上的二叉树,并指定节点node1是4,节点node2是3,这里返回的结果是True,代表4和3节点是堂兄弟节点。

添加图片注释,不超过 140 字(可选)

对于给定条件中二叉树中的节点值都是唯一的,所以要判断两个节点是否为堂兄弟节点首先要做的是定位搜索到这两个节点,其次就是在一个限定条件下可以判断这两个节点是堂兄弟节点,这个限制条件分为两部分,一就是两个节点要处在同一深度,第二就是两个节点的父节点是不同的节点,所以对于解决这个问题,适合采用广度优先搜索算法,借助于队列的形式来对所有节点进行逐层搜索,如果搜索到了指定的节点,则将该节点的深度保存成一个字典,后续即对这字典进行比较,而针对父节点不同的比较,在每个节点入队的时候,就将其深度以及父节点均入队了之后进行比较。

对队列和字典进行初始化,先将根节点入队,这里入队的信息需要有根节点的深度(深度是1),根节点本身以及根节点的父节点(根节点的父节点为空),然后进行迭代过程,将队头的节点取出,判断该节点是否是待判断的节点之一,如果是就将父节点和深度信息进行保存,以供找到两个节点之后再比较,使用python实现的代码如下:

from collections import deque
def Brother(root, node1,node2):if not root:return Falsequeue=deque([(1,root,None)])dict_={}while queue:depth,node,parent=queue.popleft()if node.val==node1:dict_[node1]=depthnode1_parent=parentif node.val==node2:node2_depth=depthnode2_parent=parent  if node.left:queue.append((depth+1,node.left,node))if node.right:queue.append((depth+1,node.right,node))if node1_parent and node2_parent:breakreturn node1_depth==node2_depth and node1_parent!=node2_parent

这篇关于python使用广度优先搜索算法求解二叉树堂兄弟节点问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/607265

相关文章

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

基于Linux的ffmpeg python的关键帧抽取

《基于Linux的ffmpegpython的关键帧抽取》本文主要介绍了基于Linux的ffmpegpython的关键帧抽取,实现以按帧或时间间隔抽取关键帧,文中通过示例代码介绍的非常详细,对大家的学... 目录1.FFmpeg的环境配置1) 创建一个虚拟环境envjavascript2) ffmpeg-py

python使用库爬取m3u8文件的示例

《python使用库爬取m3u8文件的示例》本文主要介绍了python使用库爬取m3u8文件的示例,可以使用requests、m3u8、ffmpeg等库,实现获取、解析、下载视频片段并合并等步骤,具有... 目录一、准备工作二、获取m3u8文件内容三、解析m3u8文件四、下载视频片段五、合并视频片段六、错误

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

nginx启动命令和默认配置文件的使用

《nginx启动命令和默认配置文件的使用》:本文主要介绍nginx启动命令和默认配置文件的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录常见命令nginx.conf配置文件location匹配规则图片服务器总结常见命令# 默认配置文件启动./nginx