go语言实现双向链表

简介: ```package main/* 双向链表结构体*/type DuLNodestruct{valinterface{}prefix *DuLNode// 前一个节点  rear *DuLNode// 后一个节点}/* 初始化双向链表*/func (L *DuLNode) IninDul() {L.

```

package main

/* 双向链表结构体*/

type DuLNodestruct{

valinterface{}

prefix *DuLNode// 前一个节点

  rear *DuLNode// 后一个节点

}

/* 初始化双向链表*/

func (L *DuLNode) IninDul() {

L.val = nil

L.prefix = nil

L.rear = nil

}

/* 清空双向链表*/

func (L *DuLNode) ClearDul() {

L.IninDul()

}

/* 删除双向链表*/

func (L *DuLNode) DeleteDul() {

L.IninDul()

}

/* 获取第i个结点的值*/

func (L *DuLNode) GetVal(i uint32)interface{} {

return L.val

}

/* 获取双向链表的长度*/

func (L *DuLNode) Length() uint32 {

// 双向链表为空

  if L.prefix == nil {

return 0

  }

p := L

length := uint32(1)

for p.rear != L {

length +=1

      p = p.rear

}

return length

}

/* 在第i个节点插入数据*/

func (L *DuLNode) Insert(i uint32, einterface{})  {

length := L.Length()

// 双向链表为空

  if length ==0 {

L.val, L.rear, L.prefix = e, L, L

return

  }

p := DuLNode{e, nil, nil}

// 末尾插入一个数据

  if i > length +1 {

p.rear = L.rear

L.rear.prefix = &p

p.prefix = L

return

  }

// 头部插入一个数据

  if i <=1 {

L.rear.prefix = &p

p.rear = L.rear

p.prefix = L

L = &p

return

  }

// 其他位置插入数据,n的位置为要插入的位置前一个位置节点

  n := L

for j := uint32(2);j < i;j +=1 {

n = n.rear

}

p.rear = n

n.prefix = &p

p.prefix = n

}

/* 在第i个节点删除数据,返回删除所在位置的值*/

func (L *DuLNode) Delete(i uint32)interface{} {

length := L.Length()

// 双向链表的长度等于0

  if length ==0 {

return nil

}

if i <1 {

// 删除头部节点

      L.rear.prefix = L.prefix

L.prefix.rear = L.rear

res := L.val

L = L.prefix

return res

}else if i > length {

// 删除末尾元素

      i = length

res := L.rear.val

L.rear.rear.prefix = L

L.rear = L.rear.rear

return res

}

n := L

for j := uint32(2);j < i;j +=1 {

n = n.rear

}

p := n.prefix

n.prefix = p.prefix

p.prefix.rear = n

return p.val

}

/* 依次对双向链表的每个元素调用visit().一旦visit()失败,则栈操作失败*/

func (L *DuLNode) StackTraverse(visitfunc(a ...interface{}))  {

if L.prefix == nil {

return

  }

n := L

for n != L {

visit(n)

n = n.prefix

}

}

```

目录
相关文章
|
14天前
|
存储 监控 算法
员工上网行为监控中的Go语言算法:布隆过滤器的应用
在信息化高速发展的时代,企业上网行为监管至关重要。布隆过滤器作为一种高效、节省空间的概率性数据结构,适用于大规模URL查询与匹配,是实现精准上网行为管理的理想选择。本文探讨了布隆过滤器的原理及其优缺点,并展示了如何使用Go语言实现该算法,以提升企业网络管理效率和安全性。尽管存在误报等局限性,但合理配置下,布隆过滤器为企业提供了经济有效的解决方案。
57 8
员工上网行为监控中的Go语言算法:布隆过滤器的应用
|
1月前
|
存储 Go 索引
go语言中数组和切片
go语言中数组和切片
42 7
|
1月前
|
Go 开发工具
百炼-千问模型通过openai接口构建assistant 等 go语言
由于阿里百炼平台通义千问大模型没有完善的go语言兼容openapi示例,并且官方答复assistant是不兼容openapi sdk的。 实际使用中发现是能够支持的,所以自己写了一个demo test示例,给大家做一个参考。
|
1月前
|
程序员 Go
go语言中结构体(Struct)
go语言中结构体(Struct)
103 71
|
1月前
|
存储 Go 索引
go语言中的数组(Array)
go语言中的数组(Array)
107 67
|
9天前
|
算法 安全 Go
Go 语言中实现 RSA 加解密、签名验证算法
随着互联网的发展,安全需求日益增长。非对称加密算法RSA成为密码学中的重要代表。本文介绍如何使用Go语言和[forgoer/openssl](https://github.com/forgoer/openssl)库简化RSA加解密操作,包括秘钥生成、加解密及签名验证。该库还支持AES、DES等常用算法,安装简便,代码示例清晰易懂。
41 12
|
1月前
|
存储 Go
go语言中映射
go语言中映射
38 11
|
1月前
|
Go 索引
go语言修改元素
go语言修改元素
35 6
|
12天前
|
监控 算法 安全
解锁企业计算机监控的关键:基于 Go 语言的精准洞察算法
企业计算机监控在数字化浪潮下至关重要,旨在保障信息资产安全与高效运营。利用Go语言的并发编程和系统交互能力,通过进程监控、网络行为分析及应用程序使用记录等手段,实时掌握计算机运行状态。具体实现包括获取进程信息、解析网络数据包、记录应用使用时长等,确保企业信息安全合规,提升工作效率。本文转载自:[VIPShare](https://www.vipshare.com)。
21 0
|
26天前
|
Go 数据安全/隐私保护 UED
优化Go语言中的网络连接:设置代理超时参数
优化Go语言中的网络连接:设置代理超时参数