数据结构【Golang实现】(三)——双向链表

0. 定义节点

type DNode struct {
   
	Data       any
	Prev, Next *DNode
}

// DoublyLinkedList 双向链表
type DoublyLinkedList struct {
   
	headNode *DNode
}

1. IsEmpty()

// IsEmpty 判断双向链表是否为空
func (l *LoopLinkedList) IsEmpty() bool {
   
	if l.headNode == nil {
   
		return true
	}
	return false
}

2. Length()

// Length 获取双向链表的长度(跟获取单链表长度一模一样)
func (l *DoublyLinkedList) Length() int {
   
	if l.IsEmpty() {
   
		return 0
	}
	count := 0
	currentNode := l.headNode
	for currentNode != nil {
    // 遍历完整个链表
		count++
		currentNode = currentNode.Next
	} // 结束时 currentNode = nil
	return count
}

3. AddFromHead()

// AddFromHead 从双向链表头部开始增加结点
func (l *DoublyLinkedList) AddFromHead(data any) {
   
	node := &DNode{
   Data: data}
	if l.IsEmpty() {
   
		l.headNode = node
		return
	}
	l.headNode.Prev = node
	node.Next = l.headNode
	l.headNode = node
}

4. AddFromTail()

// AddFromTail 从双向链表尾部添加结点
func 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值