链表中的一个很常见的操作是:链表的逆置,也叫链表的反转。
如:1->3->5->7->9 反转后是 9->7->5->3->1
方法一:使用指针
红色的箭头是新的变换,明白了操作原理就很好写代码了。
使用了三个指针:pre(前驱) cur(当前) rear(后继),经过以上的四步变换,目地是,使cur指向的节点成功逆置(反转)指向pre所指向的节点。后面的节点的逆置,是同样的。
关键代码是:
void reverse(Node *&head)
{
if (head == NULL || head->next==NULL) //空或者只有一个元素不用逆置
return;
Node *pre, *cur, *rear;
pre = head;
cur = head->next;
while (cur)
{
rear = cur->next;
cur->next = pre;
pre = cur;
cur = rear;
}
//以下两步,很重要
head->next = NULL; //这一步会使新的尾节点的链域置空
head =