链表

关键词:头指针、头结点、循环链表、双向链表


头指针:头指针指向链表中的第一个结点




带头结点的链表:无论链表是否为空,头结点始终存在,头结点中的值域与链表元素无关。头指针始终指向头结点




带头结点的链表的好处:不带头结点的链表,头指针是指向头结点的,在对链表进行删除、插入操作时,需要检测头结点是否发生了变化。而采用带头结点的链表,头指针指向一个始终存在且不改变的头结点,不需要进行多余的检测

循环链表:它的特点是最后一个结点的指针域指向头结点,整个链表形成一个环。由此,从链表中任意结点开始,均可找到链表中的其它结点。

图2.12

ps:如果需要对两个链表进行合并操作,可以采用设置尾指针的循环链表。在合并时,只需将一个链表的尾指针所指向结点的指针域指向另一个结点的头指针

图2.13
template<class T>
List<T>& merge(List<T> &first, List<T> &second)
{
	first.end->next = second.end->next;//第一个链表的尾结点的指针域设为第二个链表的头指针
	first.end = second.end;//链表的尾指针设为第二个链表的尾指针
	return first;
}

双向链表:即每个结点中含有两个指针域,一个指向前驱结点,一个指向后继结点

图2.14



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值