劍指offer Python 04 重建二叉樹

2021-09-19 14:24:34 字數 1172 閱讀 5714

輸入某二叉樹的前序遍歷和中序遍歷的結果,請重建出該二叉樹。假設輸入的前序遍歷和中序遍歷的結果中都不含重複的數字。例如輸入前序遍歷序列和中序遍歷序列,則重建二叉樹並返回。

樹是一種常見資料結構。除根結點外每個結點只有乙個父結點,根結點沒有父結點,除葉結點外所有結點都有乙個或多個子結點,葉結點沒有子結點。父結點與子結點之間用指標鏈結。樹的操作涉及大量指標。

面試時提到的樹大多是二叉樹。二叉樹每個結點最多只能有兩個子結點。

二叉樹中最重要的操作:遍歷,即按某一順序訪問樹中的所有結點。遍歷方式如下三種:

這三種遍歷方式都遞迴和迴圈兩種不同的實現方法。每種遍歷的遞迴實現都比迴圈實現簡捷很多

分析:二叉樹的前序遍歷中,第乙個數字總是樹的根結點的值。中序遍歷中,根結點值在序列中間,根結點左邊均為左子樹的值,右邊為右子樹的值。所以我們需要掃瞄中序遍歷序列才能找到根結點的值。

中序遍歷第乙個數字是根結點的值,掃瞄中序遍歷來確定根結點所在位置。再根據中序遍歷特點,根結點左邊均為左子樹結點的值,右邊為右子樹結點的值。這樣我們根據前序和中序遍歷找到了換份左右子樹的子串行。接下來我們可以用同樣的方法在對子序列構建左右子樹,可以用遞迴來實現。

# -*- coding:utf-8 -*-

# class treenode:

# def __init__(self, x):

# self.val = x

# self.left = none

# self.right = none

class solution:

# 返回構造的treenode根節點

def reconstructbinarytree(self, pre, tin):

# write code here

if not pre or not tin:

return none

root = treenode(pre.pop(0))

index = tin.index(root.val)

root.left = self.reconstructbinarytree(pre, tin[:index])

root.right = self.reconstructbinarytree(pre, tin[index+1 :])

return root

劍指offer(Python)替換空格

這道題要求是 將乙個字串中的空格替換成 20 有多少個空格就替換成多少個 20 例如 hello world 中間有兩個空格,則需要輸出的形式是 hello 20 20world 字串首尾的空格亦算在內。class solution def replacespace self,s return 20...

劍指offer Python 替換空格

請實現乙個函式,將乙個字串中的每個空格替換成 20 python字串,有replace方法,可以實現替換,第乙個引數是要替換的內容,第二個引數是替換的新內容 能夠快速完成,果然python作為一種高階語言,不太適合做演算法 但是 replace 相當於 insert 在替換 時,會將原字串元素的位置...

《劍指offer》python 動態規劃

動態規劃是利用空間去換取時間的演算法.主要看 1.初始條件 2.重疊子問題 3.狀態轉移方程 題目描述 乙隻青蛙一次可以跳上1級台階,也可以跳上2級。求該青蛙跳上乙個n級的台階總共有多少種跳法 先後次序不同算不同的結果 coding utf 8 class solution def jumpfloo...