数据结构之线性表——循环链表(C语言描述)

1 循环链表的定义

将单链表中最后一个数据元素的next指针指向第一个元素,如下图所示:

                            

2 循环链表的游标定义:

在循环链表中可以定义一个“当前指针”,这个指针通常称为游标,可以通过游标来遍历链表中所有元素。如下图所示:

                             

3 循环链表的具体实现分析

(1)循环链表节点指针域定义

typedef struct _tag_CircleListNode
{
	struct _tag_CircleListNode *next;
} CircleListNode;

(2)循环链表头结点定义

typedef struct _tag_CircleList
{
	CircleListNode header;//包含指针域节点
	CircleListNode *slider;//游标
	int length;//链表长度
}TCircleList;

(3)业务节点示例

struct Value
{
	CircleListNode circlenode;//包含指针域节点
	int v;
};

(4)创建循环链表

//创建循环链表
CircleList* CircleList_Create()
{
	TCircleList * ret = (TCircleList *)malloc(sizeof(TCircleList));
	if (ret == NULL)
	{
		return NULL;
	}
	ret->header.next = NULL;
	ret->length = 0;
	ret->slider = NULL;

	return ret;
}

(5)销毁循环链表

void CircleList_Destory(CircleList *list)
{
	if (list == NULL)
	{
		return;
	}
	free(list);
}

<

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值