偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Go 構(gòu)建高效的二叉搜索樹聯(lián)系簿

開發(fā) 前端
通過構(gòu)建高效的二叉搜索樹聯(lián)系簿,我們可以輕松地插入、搜索和刪除聯(lián)系人信息。使用適當(dāng)?shù)乃惴ê蛿?shù)據(jù)結(jié)構(gòu),我們能夠在O(log n)的時(shí)間復(fù)雜度內(nèi)執(zhí)行這些操作。這對于需要頻繁處理聯(lián)系人信息的應(yīng)用程序來說尤為重要。

引言

樹是一種重要的數(shù)據(jù)結(jié)構(gòu),而二叉搜索樹(BST)則是樹的一種常見形式。在本文中,我們將學(xué)習(xí)如何構(gòu)建一個(gè)高效的二叉搜索樹聯(lián)系簿,以便快速插入、搜索和刪除聯(lián)系人信息。

介紹二叉搜索樹

圖片圖片

二叉搜索樹是一種有序的二叉樹,其中每個(gè)節(jié)點(diǎn)都包含一個(gè)可比較的鍵和關(guān)聯(lián)的值。它滿足以下性質(zhì):

  • 左子樹中的所有節(jié)點(diǎn)的鍵值小于當(dāng)前節(jié)點(diǎn)的鍵值。
  • 右子樹中的所有節(jié)點(diǎn)的鍵值大于當(dāng)前節(jié)點(diǎn)的鍵值。
  • 沒有重復(fù)的節(jié)點(diǎn)。

二叉搜索樹的結(jié)構(gòu)使得在其中插入、搜索和刪除節(jié)點(diǎn)的操作都能在平均時(shí)間復(fù)雜度為O(log n)的情況下完成。

構(gòu)建聯(lián)系簿結(jié)構(gòu)

我們將使用Go語言來實(shí)現(xiàn)這個(gè)聯(lián)系簿結(jié)構(gòu)。首先,我們定義一個(gè)AddressBookNode結(jié)構(gòu)體,它代表樹中的一個(gè)節(jié)點(diǎn),并包含姓名、聯(lián)系信息以及左右子節(jié)點(diǎn)的指針。

type AddressBookNode struct {
    Name         string
    ContactInfo  string
    Left         *AddressBookNode
    Right        *AddressBookNode
}

插入聯(lián)系人

為了將聯(lián)系人添加到聯(lián)系簿中,我們實(shí)現(xiàn)了InsertContact方法。該方法接受一個(gè)姓名和聯(lián)系信息作為輸入,并根據(jù)二叉搜索樹的性質(zhì)將聯(lián)系人插入到合適的位置。

func (n *AddressBookNode) InsertContact(name, contactInfo string) *AddressBookNode {
    if n == nil {
        return &AddressBookNode{Name: name, ContactInfo: contactInfo, Left: nil, Right: nil}
    }

    if name < n.Name {
        n.Left = n.Left.InsertContact(name, contactInfo)
    } else if name > n.Name {
        n.Right = n.Right.InsertContact(name, contactInfo)
    }

    return n
}

該方法的工作原理如下:

  1. 如果當(dāng)前節(jié)點(diǎn)為空,則樹為空,我們將使用提供的姓名和聯(lián)系信息創(chuàng)建一個(gè)新的AddressBookNode,并將其作為樹的根節(jié)點(diǎn)。
  2. 如果當(dāng)前節(jié)點(diǎn)不為空,則將新聯(lián)系人的姓名與當(dāng)前節(jié)點(diǎn)的姓名進(jìn)行比較:

如果新姓名小于當(dāng)前節(jié)點(diǎn)的姓名,則在左子樹上遞歸調(diào)用InsertContact方法。

如果新姓名大于當(dāng)前節(jié)點(diǎn)的姓名,則在右子樹上遞歸調(diào)用InsertContact方法。

如果新姓名等于當(dāng)前節(jié)點(diǎn)的姓名,則可以根據(jù)實(shí)際需求進(jìn)行處理(例如,更新聯(lián)系信息)。

  1. 返回修改后的節(jié)點(diǎn)。請注意,盡管在遞歸調(diào)用期間可能會(huì)修改樹的結(jié)構(gòu),但根節(jié)點(diǎn)保持不變,并且返回修改后的樹。

搜索聯(lián)系人

為了在聯(lián)系簿中搜索聯(lián)系人,我們實(shí)現(xiàn)了SearchContact方法。該方法接受一個(gè)姓名作為輸入,并在二叉搜索樹中遞歸搜索匹配的聯(lián)系人。

func (n *AddressBookNode) SearchContact(name string) (string, bool) {
    if n == nil {
        return "", false
    }

    if name == n.Name {
        return n.ContactInfo, true
    }

    if name < n.Name {
        return n.Left.SearchContact(name)
    }
    return n.Right.SearchContact(name)
}

該方法的工作原理如下:

  1. 如果當(dāng)前節(jié)點(diǎn)為空,則表示在樹中沒有找到指定姓名的聯(lián)系人,此時(shí)方法返回一個(gè)空字符串和false。
  2. 如果目標(biāo)姓名小于當(dāng)前節(jié)點(diǎn)的姓名,則在左子樹上遞歸調(diào)用SearchContact方法。
  3. 如果目標(biāo)姓名大于當(dāng)前節(jié)點(diǎn)的姓名,則在右子樹上遞歸調(diào)用SearchContact方法。
  4. 如果目標(biāo)姓名與當(dāng)前節(jié)點(diǎn)的姓名相等,則表示找到了要搜索的聯(lián)系人節(jié)點(diǎn)。方法返回該節(jié)點(diǎn)的聯(lián)系信息和true。

刪除聯(lián)系人

為了從聯(lián)系簿中刪除聯(lián)系人,我們實(shí)現(xiàn)了DeleteContact方法。該方法接受一個(gè)姓名作為輸入,并在二叉搜索樹中遞歸刪除匹配的聯(lián)系人。

func (n *AddressBookNode) DeleteContact(name string) *AddressBookNode {
    if n == nil {
        return nil
    }

    if name < n.Name {
        n.Left = n.Left.DeleteContact(name)
    } else if name > n.Name {
        n.Right = n.Right.DeleteContact(name)
    } else {
        if n.Left == nil && n.Right == nil {
            return nil
        } else if n.Left == nil {
            return n.Right
        } else if n.Right == nil {
            return n.Left
        }

        minNode := n.Right.FindMin()
        n.Name = minNode.Name
        n.ContactInfo = minNode.ContactInfo
        n.Right = n.Right.DeleteContact(minNode.Name)
    }

    return n
}

該方法的工作原理如下:

  1. 如果當(dāng)前節(jié)點(diǎn)為空,則表示在樹中沒有找到指定姓名的聯(lián)系人,此時(shí)方法返回nil。
  2. 如果目標(biāo)姓名小于當(dāng)前節(jié)點(diǎn)的姓名,則在左子樹上遞歸調(diào)用DeleteContact方法。
  3. 如果目標(biāo)姓名大于當(dāng)前節(jié)點(diǎn)的姓名,則在右子樹上遞歸調(diào)用DeleteContact方法。
  4. 如果目標(biāo)姓名與當(dāng)前節(jié)點(diǎn)的姓名相等,則需要根據(jù)節(jié)點(diǎn)的情況進(jìn)行刪除操作:

如果目標(biāo)節(jié)點(diǎn)是葉子節(jié)點(diǎn)(沒有子節(jié)點(diǎn)),直接將其設(shè)置為nil。

如果目標(biāo)節(jié)點(diǎn)只有一個(gè)子節(jié)點(diǎn)(左子樹或右子樹),將其子節(jié)點(diǎn)替代目標(biāo)節(jié)點(diǎn)的位置。

如果目標(biāo)節(jié)點(diǎn)有兩個(gè)子節(jié)點(diǎn),則找到右子樹中的最小節(jié)點(diǎn),將其值復(fù)制到目標(biāo)節(jié)點(diǎn),并遞歸刪除最小節(jié)點(diǎn)。

總結(jié)

通過構(gòu)建高效的二叉搜索樹聯(lián)系簿,我們可以輕松地插入、搜索和刪除聯(lián)系人信息。使用適當(dāng)?shù)乃惴ê蛿?shù)據(jù)結(jié)構(gòu),我們能夠在O(log n)的時(shí)間復(fù)雜度內(nèi)執(zhí)行這些操作。這對于需要頻繁處理聯(lián)系人信息的應(yīng)用程序來說尤為重要。

責(zé)任編輯:武曉燕 來源: 愛發(fā)白日夢的后端
相關(guān)推薦

2023-07-31 08:01:13

二叉搜索測試

2021-08-31 11:35:24

二叉搜索樹迭代法公共祖先

2022-12-26 00:51:33

雙向鏈表二叉搜索樹

2022-01-11 10:01:25

二叉搜索樹數(shù)量

2021-09-03 08:58:00

二叉搜索樹節(jié)點(diǎn)

2021-09-02 11:31:28

二叉搜索樹迭代法公共祖先

2021-12-07 06:55:17

二叉搜索樹鏈表

2020-04-27 07:05:58

二叉樹左子樹右子樹

2021-08-26 11:31:11

二叉樹數(shù)據(jù)結(jié)構(gòu)算法

2023-02-13 08:02:08

哈希函數(shù)哈希表搜索樹

2021-09-07 11:01:41

二叉搜索樹序數(shù)組

2020-12-11 09:49:29

二叉樹搜索樹數(shù)據(jù)

2021-04-06 08:20:24

二叉搜索樹數(shù)據(jù)結(jié)構(gòu)算法

2020-10-11 16:56:48

二叉搜索樹代碼開發(fā)

2021-09-06 10:38:50

二叉搜索樹遞歸

2021-10-11 06:38:52

遞歸二叉搜索樹

2024-01-23 12:54:00

C++編程語言代碼

2021-04-19 07:47:42

數(shù)據(jù)結(jié)構(gòu)二叉樹Tree

2021-04-20 08:37:14

數(shù)據(jù)結(jié)構(gòu)二叉樹

2020-09-23 18:25:40

算法二叉樹多叉樹
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號