欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決Python3中二叉樹前序遍歷的迭代問題

 更新時間:2022年09月06日 08:36:23   作者:amboke  
二叉樹是分層數(shù)據(jù)結(jié)構(gòu),其中每個父節(jié)點(diǎn)最多有 2 個子節(jié)點(diǎn),在今天的文章中,我們將討論一個在大量技術(shù)編碼面試中出現(xiàn)的重要主題,對Python二叉樹遍歷相關(guān)知識感興趣的朋友一起看看吧

Python3中二叉樹前序遍歷的迭代解決方案

A Binary Tree

二叉樹是分層數(shù)據(jù)結(jié)構(gòu),其中每個父節(jié)點(diǎn)最多有 2 個子節(jié)點(diǎn)。在今天的文章中,我們將討論一個在大量技術(shù)編碼面試中出現(xiàn)的重要主題。

問題陳述 : 鑒于 二叉樹,返回 其節(jié)點(diǎn)值的前序遍歷 . 提供迭代解決方案而不是遞歸解決方案。

解決方案:

預(yù)購遍歷 在二叉樹中按以下順序發(fā)生:

  • 先訪問根
  • 遍歷左子樹
  • 遍歷右子樹

為了用迭代解決方案解決這個問題,我們必須實(shí)現(xiàn) 堆 數(shù)據(jù)結(jié)構(gòu)。這是一種非線性數(shù)據(jù)結(jié)構(gòu),其中操作按 LIFO(后進(jìn)先出)順序執(zhí)行。我們回答的方法很簡單,如下所示:

  • 我們將初始化兩個列表 IE 一個承載輸出,另一個充當(dāng)我們的堆棧數(shù)據(jù)結(jié)構(gòu)。堆棧將使用二叉樹的根值進(jìn)行初始化。
  • 然后,只要堆棧有值,我們就會在堆棧上執(zhí)行一個 while 循環(huán)。在循環(huán)中,依次進(jìn)行以下操作:
  • 刪除(彈出)堆棧中最頂部的值(根節(jié)點(diǎn))并將其附加到輸出列表
  • 將彈出值的右孩子壓入堆棧
  • 將彈出值的左孩子壓入堆棧
  • 返回循環(huán)結(jié)束時的輸出列表

作為這個過程的結(jié)果,將首先訪問根值,然后訪問左子樹,最后訪問右子樹值。

需要注意的是,右孩子首先被推入堆棧,然后是左孩子。這是因?yàn)槎褩5?LIFO 特性。這樣做將允許我們先訪問左孩子,然后再訪問右孩子。

說話很便宜,給我看代碼:

 # 二叉樹節(jié)點(diǎn)的定義 類樹節(jié)點(diǎn):  
 def __init__(self, val=0, left=None, right=None):  
 自我.val = val  
 self.left = 左  
 self.right = 對 類解決方案:  
 def preorderTraversal(self, root: Optional[TreeNode]) -> List[int]:  
 輸出,節(jié)點(diǎn)堆棧 = [],[根]  
          
 而節(jié)點(diǎn)堆棧:  
 節(jié)點(diǎn) = nodestack.pop()  
 if node: # preorder: root -> left -> right  
 output.append(node.val)  
 nodestack.append(node.right)  
 nodestack.append(node.left)  
 返回輸出

如果這篇文章對您有幫助,請隨意喜歡并訂閱我的時事通訊,以獲取更多 Python 中的 DSA 內(nèi)容。

到此這篇關(guān)于Python3中二叉樹前序遍歷的迭代解決方案的文章就介紹到這了,更多相關(guān)Python二叉樹遍歷內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python?print函數(shù)使用由淺入深全面詳解

    Python?print函數(shù)使用由淺入深全面詳解

    這篇文章主要為大家介紹了Python?print函數(shù)使用由淺入深全面詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • Python中的圖像處理之Python圖像平滑操作

    Python中的圖像處理之Python圖像平滑操作

    本文主要介紹在Python中調(diào)用OpenCV庫對圖像進(jìn)行圖像平滑濾波處理與圖像加噪處理,如雙邊濾波,高斯雙邊濾波,圖像加隨機(jī)噪聲等操作,對Python圖像平滑操作感興趣的朋友一起看看吧
    2022-06-06
  • Django 實(shí)現(xiàn)外鍵去除自動添加的后綴‘_id’

    Django 實(shí)現(xiàn)外鍵去除自動添加的后綴‘_id’

    今天小編就為大家分享一篇Django 實(shí)現(xiàn)外鍵去除自動添加的后綴‘_id’,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Django中使用Celery的方法示例

    Django中使用Celery的方法示例

    這篇文章主要介紹了Django中使用Celery的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • 詳細(xì)聊一聊為什么Python沒有main函數(shù)

    詳細(xì)聊一聊為什么Python沒有main函數(shù)

    相信很多初學(xué)python的人看代碼的時候都會先找一下main()方法,從main往下看,但事實(shí)上python中是沒有你理解中的“main()”方法的,下面這篇文章主要給大家介紹了關(guān)于為什么Python沒有main函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • Python切片操作去除字符串首尾的空格

    Python切片操作去除字符串首尾的空格

    這篇文章主要介紹了Python切片操作去除字符串首尾的空格 的相關(guān)資料,需要的朋友可以參考下
    2019-04-04
  • 利用selenium爬蟲抓取數(shù)據(jù)的基礎(chǔ)教程

    利用selenium爬蟲抓取數(shù)據(jù)的基礎(chǔ)教程

    這篇文章主要給大家介紹了關(guān)于如何利用selenium爬蟲抓取數(shù)據(jù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用selenium具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 徹底理解Python list切片原理

    徹底理解Python list切片原理

    本篇文章主要介紹了Python list切片原理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • opencv 閾值分割的具體使用

    opencv 閾值分割的具體使用

    這篇文章主要介紹了opencv 閾值分割的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • python機(jī)器學(xué)習(xí)理論與實(shí)戰(zhàn)(一)K近鄰法

    python機(jī)器學(xué)習(xí)理論與實(shí)戰(zhàn)(一)K近鄰法

    這篇文章主要為大家詳細(xì)介紹了python機(jī)器學(xué)習(xí)理論與實(shí)戰(zhàn)第一篇,K近鄰法的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01

最新評論