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

如何在Python中創(chuàng)建二叉樹

 更新時間:2021年03月30日 14:39:39   作者:English_yang  
這篇文章主要介紹了如何在Python中創(chuàng)建二叉樹,幫助大家更好的理解和學習使用python,感興趣的朋友可以了解下

前言

本文的內容是數據結構中二叉樹部分最基礎的,之所以寫一下主要是為了方便刷題的時候,能夠在自己電腦上很快的使用這種小的demo進行復雜的練習。

二叉樹節(jié)點定義

二叉樹的節(jié)點定義如下:

class TreeNode():#二叉樹節(jié)點
  def __init__(self,val,lchild=None,rchild=None):
    self.val=val		#二叉樹的節(jié)點值
    self.lchild=lchild		#左孩子
    self.rchild=rchild		#右孩子

遞歸構建二叉樹

本文使用的前序遞歸構建的方法(其余順序讀者自行變化,本文主要意在如何快速構建能夠執(zhí)行的二叉樹)
例如,我們想構建一個如下圖所示的樹(其前序遍歷結果為:abcde):

這里我們需要使用到擴展的二叉樹,也就是要告訴計算機什么是葉結點,什么是空節(jié)點,否側無法分辨左右節(jié)點。例如先序遍歷的順序為"abcde",擴展的二叉樹前序序列為:“abc##d##e##”,#代表此處節(jié)點為None,如下圖:

既然是使用遞歸的方法構建二叉樹,主要需要理解遞歸的過程,這種思路將在之后的很多地方用的到。
要知道如何遞歸的構建二叉樹,我們不能糾結于遞歸每一層到底干了什么,這樣就會一直糾結下去(所有的遞歸問題都一樣)。我們需要注意的是:

  1. 在我們的任務中,終止條件是什么?
  2. 在我們的任務中,本次遞歸要干嘛?
  3. 在我們的任務中,本次遞歸要返回給上一次遞歸的是啥?

在遞歸構建二叉樹的任務中,我們要做到不糾結于每一層,而是只關注該層在做什么,這樣,對于下圖左側的樹,我們就可以看作為右側的樹,它只有自己a (a),左子樹B (bcd)和右子樹C (e)。

這樣我們需要注意的那三個問題的回答自然就有了(做遞歸問題,心中要想著怎么回答這三個問題):

  • 在我們的任務中,終止條件是什么?

[給我們的字符用完,也就不需要再創(chuàng)建節(jié)點了]

  • 在我們的任務中,本次遞歸要干嘛?

[本次遞歸要創(chuàng)建三個節(jié)點,一個根節(jié)點,一個左節(jié)點,一個右節(jié)點]

  • 在我們的任務中,本次遞歸要返回給上一次遞歸的是啥?

[當然是返回一個本層構造好的樹的根節(jié)點]
理解了上述三個問題的回答,遞歸的代碼自然可以寫出:

def Creat_Tree(Root,val):
  if len(vals)==0:#終止條件:val用完了
    return Root
  if vals[0]!='#':#本層需要干的就是構建Root、Root.lchild、Root.rchild三個節(jié)點。
    Root = TreeNode(vals[0])
    vals.pop(0)
    Root.lchild = Creat_Tree(Root.lchild,val)
    Root.rchild = Creat_Tree(Root.rchild,val)
    return Root#本次遞歸要返回給上一次的本層構造好的樹的根節(jié)點
  else:
    Root=None
    vals.pop(0)
    return Root#本次遞歸要返回給上一次的本層構造好的樹的根節(jié)點

看懂了上述內容,構建一棵我們想象的二叉樹就很簡單了,只要輸入一個我們心目中前序遍歷擴展的二叉樹序列即可:

if __name__ == '__main__':
  Root = None
  strs="abc##d##e##"#前序遍歷擴展的二叉樹序列
  vals = list(strs)
  Roots=Creat_Tree(Root,vals)#Roots就是我們要的二叉樹的根節(jié)點。

以上就是如何在Python中創(chuàng)建二叉樹的詳細內容,更多關于Python創(chuàng)建二叉樹的資料請關注腳本之家其它相關文章!

相關文章

  • 使用Python的Twisted框架實現一個簡單的服務器

    使用Python的Twisted框架實現一個簡單的服務器

    這篇文章主要介紹了使用Python的Twisted框架實現一個簡單的服務器,翻譯自Twisted的文檔,需要的朋友可以參考下
    2015-04-04
  • 基于Python的身份證號碼自動生成程序

    基于Python的身份證號碼自動生成程序

    今天收到一個小需求:需要一個自動生成身份證號碼的小程序。近期用python較多,因此打算用python實現
    2014-08-08
  • python虛擬機pyc文件結構的深入理解

    python虛擬機pyc文件結構的深入理解

    這篇文章主要為大家介紹了python虛擬機之pyc文件結構的深入探究理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • Python中l(wèi)ist列表的賦值方法及遇到問題處理

    Python中l(wèi)ist列表的賦值方法及遇到問題處理

    這篇文章主要介紹了Python中l(wèi)ist列表的賦值方法及遇到問題處理,記錄在列表list的賦值過程中遇到的問題,并對列表的拷貝相關知識進行匯總,需要的朋友可以參考一下
    2022-03-03
  • python解決方案:WindowsError: [Error 2]

    python解決方案:WindowsError: [Error 2]

    使用Python的rename()函數重命名文件時出現問題,提示 WindowsError: [Error 2] 錯誤,需要的朋友可以參考下
    2016-08-08
  • 使用Python繪制圣誕樹教程詳解(附源代碼)

    使用Python繪制圣誕樹教程詳解(附源代碼)

    又是一年一度的圣誕節(jié)快到了,提到圣誕節(jié),就不得不提圣誕樹,所以本文我們將使用Python繪制一棵圣誕樹,文中有詳細的代碼講解,具有一定的參考價值,需要的朋友可以參考下
    2023-12-12
  • python代碼實現TSNE降維數據可視化教程

    python代碼實現TSNE降維數據可視化教程

    今天小編就為大家分享一篇python代碼實現TSNE降維數據可視化教程,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • Python繪圖之柱形圖繪制詳解

    Python繪圖之柱形圖繪制詳解

    這篇文章主要介紹了Python繪圖之柱形圖繪制詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • Python基礎 括號()[]{}的詳解

    Python基礎 括號()[]{}的詳解

    這篇文章主要介紹了Python基礎 括號()、[]、{},下面文章將圍繞這三個括號的相關解析展開內容,需要的朋友可以參考一下,洗碗粉對你有所幫助
    2021-11-11
  • numpy創(chuàng)建單位矩陣和對角矩陣的實例

    numpy創(chuàng)建單位矩陣和對角矩陣的實例

    今天小編就為大家分享一篇numpy創(chuàng)建單位矩陣和對角矩陣的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11

最新評論