单向循环链表

循环链表是一种解决单链表不能找到前驱结点问题的数据结构,它通过将链表终端结点的指针指向头结点形成环状。虽然非必须,但通常会设置头结点以统一空链表和非空链表的处理。本文涵盖了循环链表的存储结构、初始化、长度计算、插入、查找、删除、遍历以及组合等操作的程序实现。

循环链表:

   单链表只能找到后继结点,无法找到前驱结点。如果不从头结点出发 ,就无法访问到全部及诶单,为了解决这个问题,循环链表被提出。将单链表终端结点的空指针改为指向头结点,使整个链表形成一个环,这种头尾相接的单循环链表,简称为循环链表。

并不是循环链表一定要有头结点,只不过为了使空链表(rear == rear->next)与非空链表处理一致,通常会设置一个头结点。


以下为相关程序:

/* 1.循环链表存储结构代码 */

/* 2.初始循环链表 */

/* 3.循环链表长度 */

/* 4.循环链表插入 */

/* 5.循环链表查找 */

/* 6.循环链表删除 */

/* 7.遍历循环链表 */

/* 8.循环链表组合 */

#include<stdio.h>
#include<stdlib.h>

#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0

#define MAXSIZE 20 /* 存储空间初始分配量 */

typedef int Status;/* Status是函数的类型,其值是函数结果状态代码,如OK等
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值