亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何分析python二叉樹非遞歸版后序遍歷

發布時間:2021-12-13 15:57:18 來源:億速云 閱讀:214 作者:柒染 欄目:大數據

今天就跟大家聊聊有關如何分析python二叉樹非遞歸版后序遍歷,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

二叉樹的非遞歸版后序遍歷,首先定義TreeNode如下:

"""

TreeNode class

"""

class TreeNode(object):

    #constructor

    def __init__(self, val):

        self.val = val

        self.right = None

        self.left = None

    val = 0

    right = None

    left = None

非遞歸后序遍歷思路:

cur指針指向當前正遍歷到的節點,如果,

滿足情況1:不為None,且左孩子不為None,則沿著左側一直遍歷,直到不滿足條件;

如不滿足情況1,說明要么cur為None,或者左孩子為None,不管哪種情況,都先拿出stack中的最后一個元素,又細分為兩種情況:

1. cur的右孩子不為None,且未訪問過,則伸向cur的右子樹遍歷

2. 若不滿足(要么cur沒有右孩子,要么右孩子訪問過),不論哪種情況,都要訪問cur節點了,訪問后出棧,標記它為訪問過,同時當前訪問的元素置為None。


python代碼實現如下:

"""

post order using stack for binary tree

"""

def postOrderUsingStack(node=None):

    visits=[]

    stack = []

    if node is None:

        return

    stack.append(node)

    cur = node

    visited=None


    while len(stack)>0:

        if cur is not None and cur.left is not None:

            stack.append(cur.left)

            cur = cur.left

        else:

            cur =stack[-1]

            # right child for current node is not None and is not visited

            if cur.right is not None and cur.right!=visited:

                cur=cur.right

                stack.append(cur)

            else:

                # do a visit

                visits.append(cur.val)

                stack.pop()

                visited = cur

                cur=None

    return visits


單測試如下:

root = TreeNode(1)

root.left=TreeNode(2)

root.left.left = TreeNode(4)

root.right = TreeNode(3)

vals = postOrderUsingStack(root)

print(vals)

后序遍歷的結果如下:

如何分析python二叉樹非遞歸版后序遍歷

看完上述內容,你們對如何分析python二叉樹非遞歸版后序遍歷有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

隆昌县| 义马市| 湟源县| 海阳市| 南靖县| 浮梁县| 龙川县| 连云港市| 昭平县| 北宁市| 黄龙县| 邹城市| 陵水| 利辛县| 古丈县| 巴马| 东乌珠穆沁旗| 合川市| 宜宾县| 壤塘县| 刚察县| 拉孜县| 天等县| 通海县| 郁南县| 新郑市| 伊春市| 明星| 商丘市| 安吉县| 洛浦县| 永福县| 柳河县| 德江县| 响水县| 镇巴县| 久治县| 常山县| 烟台市| 宝坻区| 万宁市|