精解算法二十一(C语言版)

单链表介绍

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

要访问链表中的某个元素,从链表头开始,通过next指针从一个元素到另一个元素连续地遍历直到找到所需要的那个元素为止。以单链表来说,智能一个方向进行遍历;从头的到尾,因为每一个元素并没有维护指向其前一个元素的链接。因此,如果从链表头开始移动到某个元素,然后我们有希望访问当前位置之前的某个元素,那么再次从头开始(尽管某些时候我们事先摘掉需要访问这个元素,并保存了指向该元素的指针)。通常,这个确定不是什么大问题。当有必要的时候,可以采用双向链表或循环链表。


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





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值