当前位置:首页 > 科技  > 软件

Go 构建高效的二叉搜索树联系簿

来源: 责编: 时间:2024-01-17 10:15:24 332观看
导读引言树是一种重要的数据结构,而二叉搜索树(BST)则是树的一种常见形式。在本文中,我们将学习如何构建一个高效的二叉搜索树联系簿,以便快速插入、搜索和删除联系人信息。介绍二叉搜索树图片二叉搜索树是一种有序的二叉树,其

引言

树是一种重要的数据结构,而二叉搜索树(BST)则是树的一种常见形式。在本文中,我们将学习如何构建一个高效的二叉搜索树联系簿,以便快速插入、搜索和删除联系人信息。qAJ28资讯网——每日最新资讯28at.com

介绍二叉搜索树

图片图片qAJ28资讯网——每日最新资讯28at.com

二叉搜索树是一种有序的二叉树,其中每个节点都包含一个可比较的键和关联的值。它满足以下性质:qAJ28资讯网——每日最新资讯28at.com

  • 左子树中的所有节点的键值小于当前节点的键值。
  • 右子树中的所有节点的键值大于当前节点的键值。
  • 没有重复的节点。

二叉搜索树的结构使得在其中插入、搜索和删除节点的操作都能在平均时间复杂度为O(log n)的情况下完成。qAJ28资讯网——每日最新资讯28at.com

构建联系簿结构

我们将使用Go语言来实现这个联系簿结构。首先,我们定义一个AddressBookNode结构体,它代表树中的一个节点,并包含姓名、联系信息以及左右子节点的指针。qAJ28资讯网——每日最新资讯28at.com

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

插入联系人

为了将联系人添加到联系簿中,我们实现了InsertContact方法。该方法接受一个姓名和联系信息作为输入,并根据二叉搜索树的性质将联系人插入到合适的位置。qAJ28资讯网——每日最新资讯28at.com

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}

该方法的工作原理如下:qAJ28资讯网——每日最新资讯28at.com

  1. 如果当前节点为空,则树为空,我们将使用提供的姓名和联系信息创建一个新的AddressBookNode,并将其作为树的根节点。
  2. 如果当前节点不为空,则将新联系人的姓名与当前节点的姓名进行比较:

如果新姓名小于当前节点的姓名,则在左子树上递归调用InsertContact方法。qAJ28资讯网——每日最新资讯28at.com

如果新姓名大于当前节点的姓名,则在右子树上递归调用InsertContact方法。qAJ28资讯网——每日最新资讯28at.com

如果新姓名等于当前节点的姓名,则可以根据实际需求进行处理(例如,更新联系信息)。qAJ28资讯网——每日最新资讯28at.com

  1. 返回修改后的节点。请注意,尽管在递归调用期间可能会修改树的结构,但根节点保持不变,并且返回修改后的树。

搜索联系人

为了在联系簿中搜索联系人,我们实现了SearchContact方法。该方法接受一个姓名作为输入,并在二叉搜索树中递归搜索匹配的联系人。qAJ28资讯网——每日最新资讯28at.com

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)}

该方法的工作原理如下:qAJ28资讯网——每日最新资讯28at.com

  1. 如果当前节点为空,则表示在树中没有找到指定姓名的联系人,此时方法返回一个空字符串和false。
  2. 如果目标姓名小于当前节点的姓名,则在左子树上递归调用SearchContact方法。
  3. 如果目标姓名大于当前节点的姓名,则在右子树上递归调用SearchContact方法。
  4. 如果目标姓名与当前节点的姓名相等,则表示找到了要搜索的联系人节点。方法返回该节点的联系信息和true。

删除联系人

为了从联系簿中删除联系人,我们实现了DeleteContact方法。该方法接受一个姓名作为输入,并在二叉搜索树中递归删除匹配的联系人。qAJ28资讯网——每日最新资讯28at.com

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}

该方法的工作原理如下:qAJ28资讯网——每日最新资讯28at.com

  1. 如果当前节点为空,则表示在树中没有找到指定姓名的联系人,此时方法返回nil。
  2. 如果目标姓名小于当前节点的姓名,则在左子树上递归调用DeleteContact方法。
  3. 如果目标姓名大于当前节点的姓名,则在右子树上递归调用DeleteContact方法。
  4. 如果目标姓名与当前节点的姓名相等,则需要根据节点的情况进行删除操作:

如果目标节点是叶子节点(没有子节点),直接将其设置为nil。qAJ28资讯网——每日最新资讯28at.com

如果目标节点只有一个子节点(左子树或右子树),将其子节点替代目标节点的位置。qAJ28资讯网——每日最新资讯28at.com

如果目标节点有两个子节点,则找到右子树中的最小节点,将其值复制到目标节点,并递归删除最小节点。qAJ28资讯网——每日最新资讯28at.com

总结

通过构建高效的二叉搜索树联系簿,我们可以轻松地插入、搜索和删除联系人信息。使用适当的算法和数据结构,我们能够在O(log n)的时间复杂度内执行这些操作。这对于需要频繁处理联系人信息的应用程序来说尤为重要。qAJ28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-63233-0.htmlGo 构建高效的二叉搜索树联系簿

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Docker与Docker Compose入门:释放你应用部署的威力

下一篇: 在 Swift 中如何定义函数、定义可选参数、可变参数和函数类型

标签:
  • 热门焦点
  • 官方承诺:K60至尊版将会首批升级MIUI 15

    全新的MIUI 15今天也有了消息,在官宣了K60至尊版将会搭载天玑9200+处理器和独显芯片X7的同时,Redmi给出了官方承诺,K60至尊重大更新首批升级,会首批推送MIUI 15。也就是说虽然
  • 小米平板5 Pro 12.4简评:多专多能 兼顾影音娱乐的大屏利器

    疫情带来了网课,网课盘活了安卓平板,安卓平板市场虽然中途停滞了几年,但好的一点就是停滞的这几年行业又有了新的发展方向,例如超窄边框、高刷新率、多摄镜头组合等,这就让安卓
  • K6:面向开发人员的现代负载测试工具

    K6 是一个开源负载测试工具,可以轻松编写、运行和分析性能测试。它建立在 Go 和 JavaScript 之上,它被设计为功能强大、可扩展且易于使用。k6 可用于测试各种应用程序,包括 Web
  • 一文看懂为苹果Vision Pro开发应用程序

    译者 | 布加迪审校 | 重楼苹果的Vision Pro是一款混合现实(MR)头戴设备。Vision Pro结合了虚拟现实(VR)和增强现实(AR)的沉浸感。其高分辨率显示屏、先进的传感器和强大的处理能力
  • 分布式系统中的CAP理论,面试必问,你理解了嘛?

    对于刚刚接触分布式系统的小伙伴们来说,一提起分布式系统,就感觉高大上,深不可测。而且看了很多书和视频还是一脸懵逼。这篇文章主要使用大白话的方式,带你理解一下分布式系统
  • 学习JavaScript的10个理由...

    作者 | Simplilearn编译 | 王瑞平当你决心学习一门语言的时候,很难选择到底应该学习哪一门,常用的语言有Python、Java、JavaScript、C/CPP、PHP、Swift、C#、Ruby、Objective-
  • 电视息屏休眠仍有网络上传 爱奇艺被质疑“薅消费者羊毛”

    记者丨宁晓敏 见习生丨汗青出品丨鳌头财经(theSankei) 前不久,爱奇艺发布了一份亮眼的一季报,不仅营收和会员营收创造历史最佳表现,其运营利润也连续6个月实现增长。自去年年初
  • 英特尔Xe-HP项目终止,将专注Xe-HPC/HPG系列显卡

    据10 月 31 日消息报道,英特尔高级副总裁兼加速计算系统和图形事业部总经理 表示,Xe-HP“ Arctic Sound” 系列服务器 GPU 已经应用于 oneAPI devcloud 云服
  • “买真退假” 这种“羊毛”不能薅

    □ 法治日报 记者 王春   □ 本报通讯员 胡佳丽  2020年初,还在上大学的小东加入了一个大学生兼职QQ群。群主&ldquo;七王&rdquo;在群里介绍一些刷单赚
Top