我想知道这种方法如何用于反转链表。但我只是不知道这里发生了什么。我需要知道它是如何将指针切换到另一个方向的。谢谢你的帮助。
void reverse(struct node** head_ref)
{
Node* prev = NULL;
Node* current = *head_ref;
Node* next;
while (current != NULL)
{
next = current->next;
current->next = prev;
prev = current;
current = next;
}
*head_ref = prev;
}
答案 0 :(得分:1)
没有必要扭转这个列表,因为它是双重链接的,但这是这个函数的工作原理......
我们从一系列元素开始:
list: [A -> B -> C -> NULL]
current: A
next: UNINITIALISED
prev: NULL
首先,我们看一下元素A.它的'next'指针指向B.我们将指针指向B并将其备份到局部变量'next'中。然后我们将A的'next'指向当前的本地'previous',它当前为NULL。我们接下来更新本地'previous'指针并将其设置为A,最后将本地'current'指针设置为A的'next',即元素B.
list: [A -> NULL], [B -> C -> NULL]
current: B
next: B
prev: A
现在,我们已经完成了循环的第一次迭代,所以我们回到顶部并再次跟进。我们将本地“下一个”设置为B的“下一个”,即C。我们将B的“下一个”设置为当前的本地“前一个”,即A.最后,我们将本地“先前”更新为B并更新当地的“当前”是C。
list: [B -> A -> NULL], [C -> NULL]
current: C
next: C
prev: B
现在模式非常明显,所以我将跳过演练......
list: [C -> B -> A -> NULL]
current: NULL
next: NULL
prev: C
现在,current是NULL,所以while循环中的boolean表达式返回false,然后我们退出循环。最后发生的事情是列表的新“head”指针现在设置为指向新头C。