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

0. 定义节点

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

// DoublyLoopLinkedList 双向循环链表
type DoublyLoopLinkedList struct {
   
	headNode *DLNode
}

1. IsEmpty()

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

2. Length()

// Length 获取链表长度
func (l *DoublyLoopLinkedList) Length() int {
   
	if l.IsEmpty() {
   
		return 0
	}
	currentNode := l.headNode
	count := 1
	for currentNode.Next != l.headNode {
   
		count++
		currentNode = currentNode.Next
	}
	return count
}

3. AddFromHead()

// AddFromHead 从双向循环链表头部增加节点
func (l *DoublyLoopLinkedList) AddFromHead(data any) {
   
	node := &DLNode{
   Data: data}
	if l.IsEmpty() {
   
		l.headNode = node
		return
	}
	currentNode := l.headNode
	for currentNode.Next != l.headNode {
    // 遍历到尾结点
		currentNode = currentNode.Next
	}
	currentNode.Next = node
	l.headNode.Prev = node
	node.Prev = currentNode
	node.Next = l.headNode
	l.headN
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值