python 二叉树
时间:2019-10-24
本文章向大家介绍python 二叉树,主要包括python 二叉树使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
from __future__ import annotations
class TreeNode:
def __init__(self, value, l_node: TreeNode = None, r_node: TreeNode = None):
self.value = value
self.l_node = l_node
self.r_node = r_node
def get_value(self):
return self.value
def set_l_node(self, node: TreeNode) -> None:
self.l_node = node
def set_r_node(self, node: TreeNode) -> None:
self.r_node = node
class GenTree:
def __init__(self, values: list) -> None:
self.root = None
self.values = values
self.gen_tree()
def get_root(self) -> TreeNode:
return self.root
def gen_tree(self):
for value in self.values:
if self.root is None:
self.root = TreeNode(value)
else:
self._gen_tree(self.root, value)
def _gen_tree(self, node: TreeNode, value):
# if value < node.value:
# if node.l_node is None:
# node.l_node = TreeNode(value)
# else:
# self._gen_tree(node.l_node, value)
# else:
# if node.r_node is None:
# node.r_node = TreeNode(value)
# else:
# self._gen_tree(node.r_node, value)
def __gen_tree(l_or_r, value):
new_node = getattr(node, l_or_r)
if new_node is None:
setattr(node, l_or_r, TreeNode(value))
else:
return self._gen_tree(new_node, value)
if value < node.value:
return __gen_tree("l_node", value)
else:
return __gen_tree("r_node", value)
def pre_traverse_tree(node: TreeNode):
if node is not None:
yield node.value
yield from pre_traverse_tree(node.l_node)
yield from pre_traverse_tree(node.r_node)
def in_traverse_tree(node: TreeNode):
if node is not None:
yield from pre_traverse_tree(node.l_node)
yield node.value
yield from pre_traverse_tree(node.r_node)
root = GenTree([2, 3, 1, 4, 5]).get_root()
print(list(pre_traverse_tree(root)))
print(list(in_traverse_tree(root)))
原文地址:https://www.cnblogs.com/ywhyme/p/11731744.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 设计模式~解释器
- RTSP/GB28181/HIKSDK/Ehome协议视频上云服务平台EasyCVR人脸识别开发ArcSoftFace环境搭建
- RTSP/GB28181/HIKSDK/EHome流媒体协议视频上云网关EasyCVR流地址密码不正确如何修正?
- tmux终端意外出现控制字符
- clickhouse编译安装以及搭建mysql实时复制
- Linux回收站机制实现过程及用法详解
- Linux如何基于AIDE检测文件系统完整性
- MySQL压测时Linux中断异常飚高,原来是因为...
- Ubuntu20.04防火墙设置简易教程(小白)
- linux上搭建私有Git服务器的详细教程
- Centos7 安装 Mysql8教程
- linux下快速列出局域网中所有主机名(计算机名)的脚本
- 详解Linux重定向用法
- Zabbix基于snmp实现监控linux主机
- 快速解决linux下中文输入法问题