关键词:头指针、头结点、循环链表、双向链表
头指针:头指针指向链表中的第一个结点
带头结点的链表:无论链表是否为空,头结点始终存在,头结点中的值域与链表元素无关。头指针始终指向头结点
带头结点的链表的好处:不带头结点的链表,头指针是指向头结点的,在对链表进行删除、插入操作时,需要检测头结点是否发生了变化。而采用带头结点的链表,头指针指向一个始终存在且不改变的头结点,不需要进行多余的检测
循环链表:它的特点是最后一个结点的指针域指向头结点,整个链表形成一个环。由此,从链表中任意结点开始,均可找到链表中的其它结点。
ps:如果需要对两个链表进行合并操作,可以采用设置尾指针的循环链表。在合并时,只需将一个链表的尾指针所指向结点的指针域指向另一个结点的头指针
template<class T>
List<T>& merge(List<T> &first, List<T> &second)
{
first.end->next = second.end->next;//第一个链表的尾结点的指针域设为第二个链表的头指针
first.end = second.end;//链表的尾指针设为第二个链表的尾指针
return first;
}
双向链表:即每个结点中含有两个指针域,一个指向前驱结点,一个指向后继结点