码迷,mamicode.com
首页 > 其他好文 > 详细

链表之 头节点与尾指针 区别

时间:2016-01-15 11:04:34      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:

单链表的必要条件:头节点的head,以及尾指针指向null;  

头结点

首先,不要被以下三个词组弄混了:

链表头:数据内容为第一个元素的结点。

头指针:指向头结点元素的指针。

头结点:数据内容无效,其指针是头指针。

一句话描述为:头指针是指向头结点的指针,头结点是指向链表头的结点。


对于一个链表来说,头指针是一定存在的,是访问链表的入口,如果没有头指针则无法对其进行访问;链表头对于非空表来说是一定存在的,非空表则不存在。

2 尾指针

另外一种链表的技巧是使用尾指针。

尾指针是相对于头指针而言的,形式与头指针相同,内容只想链表的最后一个节点。

通常,链表的插入语删除操作都是在链表头或者链表尾进行。如果只保存一个头指针的话,要在链表尾操作时必须先遍历整个表,增加了时间复杂度,如果能再保存一个尾指针,则可以立即找到链表尾,时间复杂度降为O(1)。技术分享

在单向循环链表中,时常值保存一个尾指针,因为尾指针的下一个节点即是头结点。这样便可以方便地在首尾进行操作。

如果未使用头节点,在头节点处加入元素,要考虑head的变化(新加入的元素为head);同样的,若使用尾指针,那么在尾添加元素时,要注意尾指针(让新加入的元素指向null)的变化!!!!   (一句话,始终保持变化后的状态是一链表!!!)

链表之 头节点与尾指针 区别

标签:

原文地址:http://www.cnblogs.com/neversayno/p/5132599.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!