python递归实现二叉树_python3实现二叉树的遍历与递归算法解析(小结)

news/2024/7/23 9:54:12 标签: python递归实现二叉树

1、二叉树的三种遍历方式

二叉树有三种遍历方式:先序遍历,中序遍历,后续遍历 即:先中后指的是访问根节点的顺序 eg:先序 根左右 中序 左根右 后序 左右根

遍历总体思路:将树分成最小的子树,然后按照顺序输出

1.1 先序遍历

a 先访问根节点

b 访问左节点

c 访问右节点

a(b ( d ( h ) )( e ( i ) ))( c ( f )( g )) -- abdheicfg

1.2 中序遍历

a 先访问左节点

b 访问根节点

c 访问右节点

( ( ( h ) d ) b ( ( i ) e ) ) a ( ( f ) c ( g ) ) -- hdbieafcg

1.3后序遍历

a 先访问左节点

b 访问右节点

c 访问根节点

((hd)(ie)b)(fgc)a -- hdiebfgca

2、python3实现树结构

#实现树结构的类,树的节点有三个私有属性 左指针 右指针 自身的值

class Node():

def __init__(self,data=None):

self._data = data

self._left = None

self._right = None

def set_data(self,data):

self._data = data

def get_data(self):

return self._data

def set_left(self,node):

self._left = node

def get_left(self):

return self._left

def set_right(self,node):

self._right = node

def get_right(self):

return self._right

if __name__ == '__main__':

#实例化根节点

root_node = Node('a')

# root_node.set_data('a')

#实例化左子节点

left_node = Node('b')

#实例化右子节点

right_node = Node('c')

#给根节点的左指针赋值,使其指向左子节点

root_node.set_left(left_node)

#给根节点的右指针赋值,使其指向右子节点

root_node.set_right(right_node)

print(root_node.get_data(),root_node.get_left().get_data(),root_node.get_right().get_data())

3、实现树的递归遍历(前 中 后 层次遍历)

下例是树的遍历算法,其中对树的类进行了优化,

#实现树结构的类,树的节点有三个私有属性 左指针 右指针 自己的值

class Node():

def __init__(self,data =None,left=None,right = None):

self._data = data

self._left = left

self._right = right

#先序遍历 遍历过程 根左右

def pro_order(tree):

if tree == None:

return False

print(tree._data)

pro_order(tree._left)

pro_order(tree._right)

#后序遍历

def pos_order(tree):

if tree == None:

return False

# print(tree.get_data())

pos_order(tree._left)

pos_order(tree._right)

print(tree._data)

#中序遍历

def mid_order(tree):

if tree == None:

return False

# print(tree.get_data())

mid_order(tree._left)

print(tree._data)

mid_order(tree._right)

#层次遍历

def row_order(tree):

# print(tree._data)

queue = []

queue.append(tree)

while True:

if queue==[]:

break

print(queue[0]._data)

first_tree = queue[0]

if first_tree._left != None:

queue.append(first_tree._left)

if first_tree._right != None:

queue.append(first_tree._right)

queue.remove(first_tree)

if __name__ == '__main__':

tree = Node('A',Node('B',Node('D'),Node('E')),Node('C',Node('F'),Node('G')))

pro_order(tree)

mid_order(tree)

pos_order(tree)

4、递归算法

上面两张图片是从知乎贴过来的;图1中返回后会直接返回到上一级的返回,这种想法是不全面的,较合理的返回应该是如图2 在子函数返回时应返回到调用子函数的节点,这样在执行完剩余代码再返回到上一级

如果是按照图1返回的话二叉树的遍历就不能按照上例来实现。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。


http://www.niftyadmin.cn/n/896538.html

相关文章

PostgreSQL存储过程(六):结构控制和循环

结构控制和循环介绍: 作为编程语言中极为重要的知识,控制和循环可以降低代码量和减少人的工作量。在PL/PGSQL中实现了常用的控制结构和循环方法,灵活使用确实可以用来提高数据库查询的效率。 结构控制: 1. 结构:IF .…

Hive SQL进阶案例(一):使用LAG函数判断日期连续性

一、LAG函数介绍 LAG函数是一个常用的窗口函数,作用是取当前行之后的数据,即把该列数据向上错位。使用方法如下: LAG(col ,n ,Default) col是字段名称,指明要操作的列,必须指定该参数; n表示取当前行的后…

Android Spinner下拉框使用

Spinner下拉框效果如下&#xff1a; 1.activity_main.xml&#xff0c;Spinner下拉框 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"…

python oserror errorno 39_python的bug? OSError: [Errno 9] Bad file number

前面发贴问了怎么定义一个全局变量&#xff0c;后来发现不是变量作用范围的问题。运行log:rootPandora # ./TestCase.pyTraceback (most recent call last):File "./TestCase.py", line 44, in TC.setup()File "./TestCase.py", line 31, in setupGWchild.…

python 增量聚类_使用Python的四种机器学习技术

机器学习回归在一些统计书籍中&#xff0c;我们经常会发现回归是衡量一个变量的均值与其他值的对应值之间相互关系的量度。那么让我们讨论一下该如何看待它。回归均值查尔斯达尔文的表兄弟弗朗西斯高尔顿(Francis Galton)观察了几代豌豆的大小。他得出的结论是&#xff0c;自然…

Android Studio 扫描识别二维码(包含闪光灯和本地二维码)、生成二维码、生成带logo的二维码

一、测试如下: 1.扫描识别二维码,扫描结果多少 2.生成二维码、生成带logo的二维码 二、添加依赖: 1.在Project的build.gradle中添加maven { url ‘https://jitpack.io’ } allprojects {repositories {google

hotmail域名_英国短信服务商以131万元收购域名it.co.uk

据namepros论坛消息&#xff0c;上个月域名IT.uk和IT.co.uk同时易主&#xff0c;今天IT.co.uk的交易价在sedo平台曝光&#xff0c;成交价为187,200英镑&#xff0c;约合人民币131万元。背后买家是英国短信服务提供商Intis Telecom。据悉&#xff0c;域名IT.uk和IT.co.uk的交易实…

Android项目中了解jcenter()、google()、maven{}、mavenCentral()

android项目project的build.gradle中代码如下&#xff1a; buildscript {repositories { // jcenter()google()mavenCentral()}dependencies {classpath com.android.tools.build:gradle:4.2.2} }allprojects {repositories { // jcenter()google()maven { url …