一种非递归解决多叉树深度访问的方法

2024-01-29 18:58

本文主要是介绍一种非递归解决多叉树深度访问的方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 问题描述:

'''
例如:
A  A1  A11
    A2  A21  A211  A2111
                             A2112
                   A212  A2121
          A22
    A3  A31   A311
          A32   A321 A322
  A4
  
期望的输出:A A1 A11 A2 A21 A211 A2111 A2112 A212 A2121 A22 A3 A31 A311 A32 A321 A322
'''

其中,A1是A的子节点,A11是A1的子节点,A2是A的第二子节点,A21是A2的第一子节点

import reclass A:def __init__(self, name):self.name = nameself.child = []self.parent = Noneself.is_visit = Falseself.child_visit_position = -1def add_child(self, node):self.child.append(node)def set_parent(self, node):self.parent.append(node)def visit(self):self.is_visit = Truedef build_tree():tree_str = '''A A1 A11A2 A21 A211 A2111A2112A212 A2121A22A3 A31 A311A32 A321 A322A4'''result = list(filter(lambda x: x.strip(), re.split(r'[\n\r ]', tree_str)))node_map = {each: A(each) for each in result}for each in result:node = node_map.get(each)node_name = node.nameif len(node_name) == 1:continueelse:parent_name = node_name[:-1]parent_node = node_map.get(parent_name)node.parent = parent_nodeparent_node.child.append(node)return node_map.get("A")def visit_tree(root_tree: A):visit_list = []current_root = root_treewhile True:if not current_root.is_visit:visit_list.append(current_root.name)current_root.is_visit=Trueif len(current_root.child)>0:if current_root.child_visit_position < len(current_root.child)-1:current_root.child_visit_position +=1current_root = current_root.child[current_root.child_visit_position]continueif current_root.parent is not None:current_root = current_root.parentcontinueif current_root.parent is None and (len(current_root.child)<=0 or  current_root.child_visit_position >=len(current_root.child)-1):breakprint("\n".join(visit_list))root_node = build_tree()visit_tree(root_node)

这篇关于一种非递归解决多叉树深度访问的方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对

Java中Arrays类和Collections类常用方法示例详解

《Java中Arrays类和Collections类常用方法示例详解》本文总结了Java中Arrays和Collections类的常用方法,涵盖数组填充、排序、搜索、复制、列表转换等操作,帮助开发者高... 目录Arrays.fill()相关用法Arrays.toString()Arrays.sort()A

SpringBoot整合Dubbo+ZK注册失败的坑及解决

《SpringBoot整合Dubbo+ZK注册失败的坑及解决》使用Dubbo框架时,需在公共pom添加依赖,启动类加@EnableDubbo,实现类用@DubboService替代@Service,配... 目录1.先看下公共的pom(maven创建的pom工程)2.启动类上加@EnableDubbo3.实

Nginx安全防护的多种方法

《Nginx安全防护的多种方法》在生产环境中,需要隐藏Nginx的版本号,以避免泄漏Nginx的版本,使攻击者不能针对特定版本进行攻击,下面就来介绍一下Nginx安全防护的方法,感兴趣的可以了解一下... 目录核心安全配置1.编译安装 Nginx2.隐藏版本号3.限制危险请求方法4.请求限制(CC攻击防御)

nginx中端口无权限的问题解决

《nginx中端口无权限的问题解决》当Nginx日志报错bind()to80failed(13:Permissiondenied)时,这通常是由于权限不足导致Nginx无法绑定到80端口,下面就来... 目录一、问题原因分析二、解决方案1. 以 root 权限运行 Nginx(不推荐)2. 为 Nginx

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口