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

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

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端