欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

python如何實現二叉搜索樹

本篇內容主要講解“python如何實現二叉搜索樹”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“python如何實現二叉搜索樹”吧!

成都創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網綜合服務,包含不限于成都做網站、成都網站建設、盧龍網絡推廣、小程序制作、盧龍網絡營銷、盧龍企業(yè)策劃、盧龍品牌公關、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)為所有大學生創(chuàng)業(yè)者提供盧龍建站搭建服務,24小時服務熱線:18980820575,官方網址:aaarwkj.com

樹的介紹

樹不同于鏈表或哈希表,是一種非線性數據結構,樹分為二叉樹、二叉搜索樹、B樹、B+樹、紅黑樹等等。

樹是一種數據結構,它是由n個有限節(jié)點組成的一個具有層次關系的集合。用圖片來表示的話,可以看到它很像一棵倒掛著的樹。因此我們將這類數據結構統(tǒng)稱為樹,樹根在上面,樹葉在下面。一般的樹具有以下特點:

  • 每個節(jié)點有0個或者多個子節(jié)點

  • 沒有父節(jié)點的節(jié)點被稱為根節(jié)點

  • 每個非根節(jié)點有且只有一個父節(jié)點

  • 每個子結點都可以分為多個不相交的子樹

二叉樹的定義是:每個節(jié)點最多有兩個子節(jié)點。即每個節(jié)點只能有以下四種情況:

  • 左子樹和右子樹均為空

  • 只存在左子樹

  • 只存在右子樹

  • 左子樹和右子樹均存在

二叉搜索樹

二叉搜索樹又稱二叉排序樹,它或者是一棵空樹,或者是具有以下性質的二叉樹:

  • 若它的左子樹不為空,則左子樹上所有節(jié)點的值都小于根節(jié)點的值 若它的右子樹不為空,則右子樹上所有節(jié)點的值都大于根節(jié)點的值

  • 它的左右子樹也分別為二叉搜索樹

列舉幾種Python中幾種常見的實現方式:

1.使用類和遞歸函數實現

通過定義一個節(jié)點類,包含節(jié)點值、左右子節(jié)點等屬性,然后通過遞歸函數實現插入、查找、刪除等操作。代碼示例如下:

class Node:
    def __init__(self, data):
        self.data = data
        self.left = None
        self.right = None

class BST:
    def __init__(self):
        self.root = None

    def insert(self, value):
        if self.root is None:
            self.root = Node(value)
        else:
            self._insert(value, self.root)

    def _insert(self, value, node):
        if value < node.data:
            if node.left is None:
                node.left = Node(value)
            else:
                self._insert(value, node.left)
        elif value > node.data:
            if node.right is None:
                node.right = Node(value)
            else:
                self._insert(value, node.right)

    def search(self, value):
        if self.root is None:
            return False
        else:
            return self._search(value, self.root)

    def _search(self, value, node):
        if node is None:
            return False
        elif node.data == value:
            return True
        elif value < node.data:
            return self._search(value, node.left)
        else:
            return self._search(value, node.right)

    def delete(self, value):
        if self.root is None:
            return False
        else:
            self.root = self._delete(value, self.root)

    def _delete(self, value, node):
        if node is None:
            return node
        elif value < node.data:
            node.left = self._delete(value, node.left)
        elif value > node.data:
            node.right = self._delete(value, node.right)
        else:
            if node.left is None and node.right is None:
                del node
                return None
            elif node.left is None:
                temp = node.right
                del node
                return temp
            elif node.right is None:
                temp = node.left
                del node
                return temp
            else:
                temp = self._find_min(node.right)
                node.data = temp.data
                node.right = self._delete(temp.data, node.right)
        return node

    def _find_min(self, node):
        while node.left is not None:
            node = node.left
        return node
2.使用列表實現

通過使用一個列表來存儲二叉搜索樹的元素,然后通過列表中元素的位置關系來實現插入、查找、刪除等操作。代碼示例如下:

class BST:
    def __init__(self):
        self.values = []

    def insert(self, value):
        if len(self.values) == 0:
            self.values.append(value)
        else:
            self._insert(value, 0)

    def _insert(self, value, index):
        if value < self.values[index]:
            left_child_index = 2 * index + 1
            if left_child_index >= len(self.values):
                self.values.extend([None] * (left_child_index - len(self.values) + 1))
            if self.values[left_child_index] is None:
                self.values[left_child_index] = value
            else:
                self._insert(value, left_child_index)
        else:
            right_child_index = 2 * index + 2
            if right_child_index >= len(self.values):
                self.values.extend([None] * (right_child_index - len(self.values) + 1))
            if self.values[right_child_index] is None:
                self.values[right_child_index] = value
            else:
                self._insert(value, right_child_index)

    def search(self, value):
        if value in self.values:
            return True
        else:
            return False

    def delete(self, value):
        if value not in self.values:
            return False
        else:
            index = self.values.index(value)
            self._delete(index)
            return True

    def _delete(self, index):
        left_child_index = 2 * index + 1
        right_child_index = 2 * index + 2
        if left_child_index < len(self.values) and self.values[left_child_index] is not None:
            self._delete(left_child_index)
        if right_child_index < len(self.values) and self.values[right_child_index] is not None:
            self
3.使用字典實現

其中字典的鍵表示節(jié)點值,字典的值是一個包含左右子節(jié)點的字典。代碼示例如下:

def insert(tree, value):
    if not tree:
        return {value: {}}
    elif value < list(tree.keys())[0]:
        tree[list(tree.keys())[0]] = insert(tree[list(tree.keys())[0]], value)
    else:
        tree[list(tree.keys())[0]][value] = {}
    return tree

def search(tree, value):
    if not tree:
        return False
    elif list(tree.keys())[0] == value:
        return True
    elif value < list(tree.keys())[0]:
        return search(tree[list(tree.keys())[0]], value)
    else:
        return search(tree[list(tree.keys())[0]].get(value), value)

def delete(tree, value):
    if not search(tree, value):
        return False
    else:
        if list(tree.keys())[0] == value:
            if not tree[list(tree.keys())[0]]:
                del tree[list(tree.keys())[0]]
            elif len(tree[list(tree.keys())[0]]) == 1:
                tree[list(tree.keys())[0]] = list(tree[list(tree.keys())[0]].values())[0]
            else:
                min_key = min(list(tree[list(tree.keys())[0]+1].keys()))
                tree[min_key] = tree[list(tree.keys())[0]+1][min_key]
                tree[min_key][list(tree.keys())[0]] = tree[list(tree.keys())[0]]
                del tree[list(tree.keys())[0]]
        elif value < list(tree.keys())[0]:
            tree[list(tree.keys())[0]] = delete(tree[list(tree.keys())[0]], value)
        else:
            tree[list(tree.keys())[0]][value] = delete(tree[list(tree.keys())[0]].get(value), value)
    return tree

由于字典是無序的,因此該實現方式可能會導致二叉搜索樹不平衡,影響插入、查找和刪除操作的效率。

4.使用堆棧實現

使用堆棧(Stack)可以實現一種簡單的二叉搜索樹,可以通過迭代方式實現插入、查找、刪除等操作。具體實現過程如下:

  • 定義一個節(jié)點類,包含節(jié)點值、左右子節(jié)點等屬性。

  • 定義一個堆棧,初始時將根節(jié)點入棧。

  • 當棧不為空時,取出棧頂元素,并對其進行操作:如果要插入的值小于當前節(jié)點值,則將要插入的值作為左子節(jié)點插入,并將左子節(jié)點入棧;如果要插入的值大于當前節(jié)點值,則將要插入的值作為右子節(jié)點插入,并將右子節(jié)點入棧;如果要查找或刪除的值等于當前節(jié)點值,則返回或刪除該節(jié)點。

  • 操作完成后,繼續(xù)從堆棧中取出下一個節(jié)點進行操作,直到堆棧為空。

需要注意的是,在這種實現方式中,由于使用了堆棧來存儲遍歷樹的過程,因此可能會導致內存占用較高。另外,由于堆棧的特性,這種實現方式只能支持深度優(yōu)先遍歷(Depth-First Search,DFS),不能支持廣度優(yōu)先遍歷(Breadth-First Search,BFS)。

以下是偽代碼示例:

class Node:
    def __init__(self, data):
        self.data = data
        self.left = None
        self.right = None

def insert(root, value):
    if not root:
        return Node(value)
    stack = [root]
    while stack:
        node = stack.pop()
        if value < node.data:
            if node.left is None:
                node.left = Node(value)
                break
            else:
                stack.append(node.left)
        elif value > node.data:
            if node.right is None:
                node.right = Node(value)
                break
            else:
                stack.append(node.right)

def search(root, value):
    stack = [root]
    while stack:
        node = stack.pop()
        if node.data == value:
            return True
        elif value < node.data and node.left:
            stack.append(node.left)
        elif value > node.data and node.right:
            stack.append(node.right)
    return False

def delete(root, value):
    if root is None:
        return None
    if value < root.data:
        root.left = delete(root.left, value)
    elif value > root.data:
        root.right = delete(root.right, value)
    else:
        if root.left is None:
            temp = root.right
            del root
            return temp
        elif root.right is None:
            temp = root.left
            del root
            return temp
        else:
            temp = root.right
            while temp.left is not None:
                temp = temp.left
            root.data = temp.data
            root.right = delete(root.right, temp.data)
    return root

到此,相信大家對“python如何實現二叉搜索樹”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!

當前標題:python如何實現二叉搜索樹
本文網址:http://aaarwkj.com/article38/jpopsp.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供云服務器、、品牌網站設計定制網站、域名注冊面包屑導航

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
午夜在线观看欧美福利| 女同av免费观看网站| 日本精品在线亚洲国产欧美| 综合久久精品亚洲天堂| 国产精品一区在线播放| 在线中文字幕日韩有码| 高清国产国产精品三级国产av| 久久国产福利一区二区| 成年视频免费观看视频| 尤物视频最新在线观看| 日本在线观看成人大片| 亚洲日本在线观看一区| 欧美日韩午夜久久免费| 台湾三级一区二区三区| 日韩欧美一区二区狠狠插| 亚洲美女毛茸茸的逼逼| 亚洲av毛片在线免费播放| 久久久久亚洲av成人| 欧美日韩国产一区二区的| 亚洲日本欧洲二区精品| 九九热这里只有免费视频| 精品久久精品久久人妻九色| 97国产精品亚洲精品| 欧美精品一区二区毛卡片| av天堂男人站在线观看| 国产一区二区三区百合| 国产日韩精品一区二区三区在线| 欧美日韩在线高清一区二区| 精品国产亚洲av剧情| 欧美黄色一级在线免费观看| 色爱区偷拍人妻中文字幕| 国产又粗又长又爽网站| 海角社区av在线播放| 另类欧美亚洲中文在线综合 | 亚洲综合色一区二区三区小说| av在线高清免费观看| 97在线视频观看视频在线| 精品一区无遮挡免费网站| 精品嫩模福利一区二区蜜臀 | 精品一区二区视频在线观看网站| 五月婷婷少妇中文字幕|