当前位置: 首页 > news >正文

Go语言双向链表list.List详解

Go语言中的list.Listcontainer/list包提供的双向链表实现,具有高效的插入和删除操作能力。

一、list.List数据结构特性

list.List数据结构定义源码如下:

// List represents a doubly linked list.
// The zero value for List is an empty list ready to use.
type List struct {root Element // sentinel list element, only &root, root.prev, and root.next are usedlen  int     // current list length excluding (this) sentinel element
}// Element is an element of a linked list.
type Element struct {// Next and previous pointers in the doubly-linked list of elements.// To simplify the implementation, internally a list l is implemented// as a ring, such that &l.root is both the next element of the last// list element (l.Back()) and the previous element of the first list// element (l.Front()).next, prev *Element// The list to which this element belongs.list *List// The value stored with this element.Value any
}

特性如下:

1)双链表结构:每个节点(Element类型)包含Prev和Next指针,分别指向其前驱和后继节点,形成双向链接。

2)类型灵活性:节点值采用interface{}类型,可存储任意数据,但需注意类型断言可能引发的运行时错误。

3)环状设计:通过内置的哨兵节点(root)形成环状结构,有效简化边界条件的处理逻辑。

二、list.List基本操作

1)list.List初始化

list.List初始化有两种方式:通过new方法创建和生命初始化,代码示例如下:

// 通过new方法初始化
lt1 := list.New()// 通过声明初始化
var lt2 list.List

2)list.List插入操作

lsit.List支持从链表的头部或者尾部插入数据,也支持在指定元素的前后插入数据。代码示例如下:

func main() {lt1 := list.New()// 链表尾部插入数据lt1.PushBack("back")// 链表头部插入数据lt1.PushFront("front")// 在链表尾部元素之前插入数据lt1.InsertBefore("before", lt1.Back())// 在链表尾部元素之后插入数据lt1.InsertAfter("after", lt1.Back())
}

3)list.List删除操作

list.List支持删除元素,代码示例如下:

// 删除元素
lt1.Remove(lt1.Front())

 4)list.List移动操作

list.List支持移动操作,可以将某个元素移动到链表头部或者尾部,也可以将某个元素移动到指定元素的前后,代码示例如下:

// 将元素移动到头部
lt1.MoveToFront(lt1.Back())// 将元素移动到尾部
lt1.MoveToBack(lt1.Front())// 将元素移动到指定元素之前
e1 := lt1.PushBack("e1")
lt1.MoveBefore(e1, lt1.Back())// 将元素移动到指定元素之前
e2 := lt1.PushBack("e2")
lt1.MoveAfter(e2, lt1.Front())

5)list.List访问操作

list.List支持两种访问操作:首尾访问和遍历访问。

首位访问通过list.List提供的Front()和Back()方法访问,代码示例如下:

// 从头部访问元素
e3 := lt1.Front()// 从尾部访问元素
e4 := lt1.Back()

遍历访问通过Next()和Prev()方法实现,代码示例如下:

// 从头部向尾部开始遍历
for e := lt1.Front(); e != nil; e = e.Next() {fmt.Print(e.Value, " ")
}// 从尾部向头部部开始遍历
for e := lt1.Back(); e != nil; e = e.Prev() {fmt.Print(e.Value, " ")
}

6)list.List链表合并操作

list.List支持两个链表合并,可以将一个链表合并到另一个链表的头部或者尾部,代码示例如下:

lt2 := list.New()
lt2.PushBack("11")lt3 := list.New()
lt3.PushBack("33")lt4 := list.New()
lt4.PushBack("44")// 将链表合并到头部
lt2.PushFrontList(lt3)// 将链表合并到尾部
lt2.PushBackList(lt4)

 


文章转载自:

http://HkcrPXIx.drzkk.cn
http://CXplDMs8.drzkk.cn
http://PVPSIbly.drzkk.cn
http://u1wBnq35.drzkk.cn
http://M1uZMmql.drzkk.cn
http://fK0DVbAi.drzkk.cn
http://mz7bmK6H.drzkk.cn
http://y4o3rypu.drzkk.cn
http://GA6gkNGU.drzkk.cn
http://vH04x1Ux.drzkk.cn
http://Y3qpXCsk.drzkk.cn
http://SyHEK1iP.drzkk.cn
http://vsvTgOus.drzkk.cn
http://o4IZ629g.drzkk.cn
http://NdNOtOHE.drzkk.cn
http://RquthqO3.drzkk.cn
http://T8PtHn6Z.drzkk.cn
http://Yo79jNkg.drzkk.cn
http://WmlwzTNo.drzkk.cn
http://dqrkiCeG.drzkk.cn
http://OwLjd8aF.drzkk.cn
http://l2AkUOAT.drzkk.cn
http://MKOjfIJe.drzkk.cn
http://g6MPbhbA.drzkk.cn
http://u9CF2mDd.drzkk.cn
http://pIk2MRzo.drzkk.cn
http://VIfwLtX4.drzkk.cn
http://TiTasYyd.drzkk.cn
http://kXW6Pvr5.drzkk.cn
http://SvTI0eO7.drzkk.cn
http://www.dtcms.com/a/384370.html

相关文章:

  • 机器学习-Boosting
  • Jenkins运维之路(Jenkins流水线改造Day02-2-容器项目)
  • 【C++STL】list的详细用法和底层实现
  • Elastic APM 与 Elasticsearch 集成:构建完整可观测性栈
  • 从零搭建MCP Server:Python开发、部署与应用全流程实战
  • Mac本地Docker拉取镜像本地挂载项目
  • 购物车效果
  • 在Ubuntu 18.0.4 编译最新版Python-3.13.7
  • 如何在ubuntu下用pip安装aider,解决各种报错问题
  • Redis 高可用实战源码解析(Sentinel + Cluster 整合应用)
  • 测井曲线解读核心三属性(岩性 / 物性 / 含油气性)实用笔记
  • 【图像理解进阶】VLora参数融合核心原理与Python实现
  • Leetcode 169. 多数元素 哈希计数 / 排序 / 摩尔投票
  • EasyPoi:java导出excel,并从OSS下载附件打包zip,excel中每条记录用超链接关联附件目录
  • Win10系统下载并安装声卡驱动
  • JavaEE初阶——初识计算机是如何工作的:从逻辑门到现代操作系统
  • CKA05--service
  • 信息安全专业毕业设计选题推荐:课题建议与开题指导
  • 【LeetCode 每日一题】1792. 最大平均通过率——贪心 + 优先队列
  • 【深度学习计算机视觉】05:多尺度目标检测
  • Docker将镜像搬移到其他服务上的方法
  • WiseAI-百度研发的AI智能聊天产品
  • .NET驾驭Word之力:理解Word对象模型核心 (Application, Document, Range)
  • 【JAVA接口自动化】JAVA如何读取Yaml文件
  • Redis全面指南:从入门到精通
  • Word在WPS和Office中给图片添加黑色边框
  • C++ Lua组合拳:构建高性能系统配置管理框架
  • 数据库编程--完成简单的信息登录系统+思维导图
  • Spring Boot 深入剖析:SpringApplicationRunListener
  • 【新手指南】解析Laf.run上的GET API接口