日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

多线程python 客户端fuwuq实现方式_python实现二叉树数据结构的多种遍历方式

發(fā)布時(shí)間:2025/3/20 python 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 多线程python 客户端fuwuq实现方式_python实现二叉树数据结构的多种遍历方式 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

二叉樹的遍歷比較有意思,首先是遍歷的方式比較多,大的來說分為深度遍歷和廣度遍歷,深度遍歷又分為先序遍歷/中序遍歷/后序遍歷,其中深度遍歷用遞歸來實(shí)現(xiàn),廣度遍歷用隊(duì)列來實(shí)現(xiàn)。

深度遍歷和廣度遍歷是相對(duì)的概念,深度遍歷是沿著樹的深度遍歷樹的節(jié)點(diǎn),盡可能深的搜索樹的分支;廣度遍歷是從樹的根層級(jí)開始一層一層的遍歷,遍歷完上一層再遍歷下一層;如下:

深度遍歷順序:0-1-3-7-8-4-9-2-5-6(先序遍歷)

廣度遍歷順序:0-1-2-3-4-5-6-7-8-9

但對(duì)于深度遍歷而言還有三種方式:先序遍歷/中序遍歷/后序遍歷;先序遍歷的順序?yàn)?#xff1a;根節(jié)點(diǎn)->左子樹->右子樹;中序遍歷為:左子樹->根節(jié)點(diǎn)->右子樹;當(dāng)然后序遍歷是:左子樹->右子樹->根節(jié)點(diǎn);其中的序指的是根節(jié)點(diǎn)相對(duì)于左右節(jié)點(diǎn)的遍歷位置。

在上二叉樹中我們按照深度遍歷的三種方式得到的順序如下:

先序遍歷:0-1-3-7-8-4-9-2-5-6

中序遍歷:7-3-8-1-9-4-0-5-2-6

后序遍歷:7-8-3-9-4-1-5-6-2-0

注意:先序遍歷是從上往下看,中序遍歷和后續(xù)遍歷是從下往上看,從哪里開始就決定了什么相對(duì)簡單二叉樹的權(quán)重。

深度遍歷的實(shí)現(xiàn):

class Node:"""節(jié)點(diǎn)類"""def __init__(self, elem, lchild=None, rchild=None):self.elem = elemself.lchild = lchildself.rchild = rchildclass Tree:"""樹類"""def __init__(self, root=None):self._root = rootdef add(self, item):node = Node(item)if not self._root:self._root = nodereturnqueue = [self._root]while queue:cur = queue.pop(0)if not cur.lchild:cur.lchild = nodereturnelif not cur.rchild:cur.rchild = nodereturnelse:queue.append(cur.rchild)queue.append(cur.lchild)def preorder(self, root):"""先序遍歷-遞歸實(shí)現(xiàn):param root::return:"""if not root:raise ValueError("ROOT ERROR")print(root.elem)self.preorder(root.lchild)self.preorder(root.rchild)def inorder(self, root):"""中序遍歷-遞歸實(shí)現(xiàn):param root::return:"""if not root:raise ValueError("ROOT ERROR")self.inorder(root.lchild)print(root.elem)self.inorder(root.rchild)def postorder(self, root):"""后序遍歷-遞歸實(shí)現(xiàn):param root: :return: """if not root:raise ValueError("ROOT ERROR")self.postorder(root.lchild)self.postorder(root.rchild)print(root.elem)

廣度遍歷的實(shí)現(xiàn);

class Node:"""節(jié)點(diǎn)類"""def __init__(self, elem, lchild=None, rchild=None):self.elem = elemself.lchild = lchildself.rchild = rchildclass Tree:"""樹類"""def __init__(self, root=None):self._root = rootdef breadth_travel(self, root):"""廣度優(yōu)先-隊(duì)列實(shí)現(xiàn):param root::return:"""if not root:raise ValueError("ROOT ERROR")queue = [root]while queue:node = queue.pop(0)print(node.elem)if node.lchild:queue.append(node.lchild)elif node.rchild:queue.append(node.rchild)

遞歸函數(shù)使得二叉樹的遍歷操作更加的簡潔,上面的深度遍歷的三種方式除了遞歸以外,還可以使用堆棧的結(jié)構(gòu)來實(shí)現(xiàn),如果感興趣可自行實(shí)現(xiàn)。

總結(jié)

以上是生活随笔為你收集整理的多线程python 客户端fuwuq实现方式_python实现二叉树数据结构的多种遍历方式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。