算法精解_C语言 链表_单链表(接口定义+类型实现)

链表可以说是一种最为基础的数据结构。链表由一组元素以一种特定的顺序组合或链接而成,在维护数据的集合时很有用。这一点同我们常用的数组很相似。然而,链表在很多情况下比数组更有优势。特别是在执行插入和删除操作时链表拥有更高的效率。链表需要动态的开辟存储空间,也就是存储空间是在程序运行时分配的。由于在很多应用中数据的大小在编译时并不能确定,因此这种动态分配空间的特性也是链表的一个优点。

单链表介绍

单链表(简称为链表)由各个元素之间通过一个指针彼此链接起来而组成。每个元素包含两个部分:数据成员和一个称为next的指针。通过采用这种二成员的结构,将每个元素的next指针设置为指向其后面的元素(见图1)。最后一个元素的next指针设置为NULL,简单的表示链表的尾端。链表开始处的元素是“头”,链表未尾的元素称为尾。

要访问链表中的某个元素,从链表头开始,通过next指针从一个元素到另一个元素连续地遍历直到找到所需要的那个元素为止。以单链表来说,只能以一个方向进行遍历:从头到尾,因为每个元素并没有维护指向其前一个元素的链接。

从概念上说,可以把链表想象成一系列连续的元素。然而,由于这些元素是动态分配的(在C语言中调用malloc),因此很重要的一点是,切记这些元素通常实际上都是分散在内存空间中的(见图2)。元素与元素之前的链接关系只是为了确保所有的元素都可以访问到。带着这种思考,我们将会看到当维护元素之间的链接信息时需要特别小心。如果我们错误地丢失了一个链接,则从这个位置开始,往后的所有元素都无法访问到了。“你的弱点有多弱,你的强度就有多强”,非常适用于描述链表的特点。


单链表接口的定义

list_init                                                                         

void list_init(List *list,void (*destroy)(void *data));

返回值 无

描述  初始化由list指定的链表。

该函数必须在链表做其他操作之前调用。当调用list_destroy时,destroy参数提供了一种释放动态分配的数据的方法。例如,如果链表包含采用malloc动态分配的数据,当链表被销毁时,destroy应该设置为free用来释放数据。对于包含好几个动态分配成员的结构化数据,destroy应该设置为一个用户自定义的析构函数,通过对每一个动态分配的成员以及对结构体自身调用free来释放数据。如果链表包含不应该释放的数据,destroy应该设置为null。

复杂度   O(1)


list_destroy                         

void list_destroy(List *list);

返回值 无

描述  销毁由参数list指定的链表。

调用list_destroy后任何其他的操作都不允许执行,除非再次调用list_init。list_destroy将链表中所有的元素都移除,如果传给list_init的参数destroy不为null,则移除链表中每个元素时都调用该函数一次。

复杂度  O(n),n代表链表中的元素个数


list_ins_next                                                                                         

int list_ins_next(List *list,ListElmt *element,const void *data);

返回值  如果插入元素成功则返回0,否则返回-1.

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值